IN&EXISTS与NOT IN&NOT EXISTS 的优化原则小结
下面只是从理论上提出了一些建议,最好的原则是大家在上面的基础上,能够使用执行计划来分析,得出最佳的语句的写法。
1. EXISTS的执行流程select * from t1 where exists ( select null from t2 where y = x )
可以理解为:
代码如下:
for x in ( select * from t1 )
loop
if ( exists ( select null from t2 where y = x.x )
then
OUTPUT THE RECORD
end if
end loop
对于in 和 exists的性能区别:
如果子查询得出的结果集记录较少,主查询中的表较大且又有索引时应该用in,反之如果外层的主查询记录较少,子查询中的表大,又有索引时使用exists。
其实我们区分in和exists主要是造成了驱动顺序的改变(这是性能变化的关键),如果是exists,那么以外层表为驱动表,先被访问,如果是IN,那么先执行子查询,所以我们会以驱动表的快速返回为目标,那么就会考虑到索引及结果集的关系了
另外IN时不对NULL进行处理,如:
select 1 from dual where null in (0,1,2,null)
结果为空。
2. NOT IN 与NOT EXISTS:
NOT EXISTS的执行流程
代码如下:
select .....
from rollup R
where not exists ( select 'Found' from title T
where R.source_id = T.Title_ID);
可以理解为:
代码如下:
for x in ( select * from rollup )
loop
if ( not exists ( that query ) ) then
OUTPUT
end if;
end;
注意:NOT EXISTS 与 NOT IN 不能完全互相替换,看具体的需求。如果选择的列可以为空,则不能被替换。
例如下面语句,看他们的区别:
select x,y from t;
x y
------ ------
1 3
3 1
1 2
1 1
3 1
5
select * from t where x not in (select y from t t2 )
no rows
select * from t where not exists (select null from t t2
where t2.y=t.x )
x y
------ ------
5 NULL
所以要具体需求来决定
对于not in 和 not exists的性能区别:
not in 只有当子查询中,select 关键字后的字段有not null约束或者有这种暗示时用not in,另外如果主查询中表大,子查询中的表小但是记录多,则应当使用not in,并使用anti hash join.
如果主查询表中记录少,子查询表中记录多,并有索引,可以使用not exists,另外not in最好也可以用/*+ HASH_AJ */或者外连接+is null
NOT IN 在基于成本的应用中较好
比如:
代码如下:
select .....
from rollup R
where not exists ( select 'Found' from title T
where R.source_id = T.Title_ID);
改成(佳)
select ......
from title T, rollup R
where R.source_id = T.Title_id(+)
and T.Title_id is null;
或者(佳)
sql> select /*+ HASH_AJ */ ...
from rollup R
where ource_id NOT IN ( select ource_id
from title T
where ource_id IS NOT NULL )
注意:上面只是从理论上提出了一些建议,最好的原则是大家在上面的基础上,能够使用执行计划来分析,得出最佳的语句的写法。
'//=============================
exists,not exists总结
1 exists
SELECT * FROM anken_m WHERE EXISTS(
SELECT my_list_temp_m.sales_code
FROM my_list_temp_m
WHERE my_list_temp_m.sales_code=anken_m.sales_code)
说明:
1) 查询在anken_m表和my_list_temp_m表中都存在的sales_code。
2) sales_code是anken_m的主键,my_list_temp_m的外键。
注意:
1) 外层查询表anken_m是查询的对象。
2) 内层查询表my_list_temp_m是条件对象。
3) 内外层的查询表不能相同。
4) 作为关联条件的anken_m表不需要在内层查询FROM后添加。
5) my_list_temp_m.sales_code=anken_m.sales_code条件的左右顺序不影响查询结果。
2 not exists
SELECT * FROM anken_m WHERE NOT EXISTS(
SELECT my_list_temp_m.sales_code
FROM my_list_temp_m
WHERE my_list_temp_m.sales_code=anken_m.sales_code)
说明:
1) 查询在anken_m表中存在,但是在my_list_temp_m表中不存在的sales_code。
2) sales_code是anken_m的主键,my_list_temp_m的外键。
注意:
1) 外层查询表anken_m是查询的对象。
2) 内层查询表my_list_temp_m是条件对象。
3) 内外层的查询表不能相同。
4) 作为关联条件的anken_m表不需要在内层查询FROM后添加。
5) my_list_temp_m.sales_code=anken_m.sales_code条件的左右顺序不影响查询结果。
3 综合运用
UPDATE anken_m
SET(plan_type_code, branch_name, business_type_code)
=(SELECT anken.plan_type_code,anken.branch_name,anken.business_type_code
FROM anken
WHERE anken.sales_code=anken_m.sales_code)
WHERE EXISTS (
SELECT anken.sales_code
FROM anken,my_list_temp_m
WHERE my_list_temp_m.sales_code=anken.sales_code
AND anken.sales_code=anken_m.sales_code
)
说明:
1) 用一个表的记录数据更新另一个表的记录数据。
2) 用一个SQL语句进行批量更新。
2) sales_code是anken,anken_m的主键,my_list_temp_m的外键。
注意:
1) set 语句中的要被更新字段必须跟数据源字段一一对应,另外数据源查询中的条件必须限定一条记录。也就是根据sales_code可以唯一确定anken的一条记录,和anken_m的一条记录,这样才能保证要被更新的记录和数据源记录的主键是相同的。
2) 根据WHERE EXISTS语句可以确定数据源记录的范围,也就是可以用anken表中哪些记录更新anken_m表。所以anken_m不需要在WHERE EXISTS语句中的FROM后添加。

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas











Dengan pembangunan pengantarabangsaan yang berterusan, semakin banyak laman web dan aplikasi perlu menyokong fungsi penukaran berbilang bahasa. Sebagai rangka kerja bahagian hadapan yang popular, Vue menyediakan pemalam yang dipanggil i18n yang boleh membantu kami mencapai penukaran berbilang bahasa. Artikel ini akan memperkenalkan teknik biasa untuk menggunakan i18n untuk mencapai penukaran berbilang bahasa dalam Vue. Langkah 1: Pasang pemalam i18n Mula-mula, kita perlu menggunakan npm atau benang untuk memasang pemalam i18n. Masukkan arahan berikut pada baris arahan: npminst

Antara muka keluar merujuk kepada antara muka keluaran, dan antara muka masuk merujuk kepada antara muka masukan. Antara muka keluar secara amnya mewakili antara muka keluaran talian sumber audio, yang digunakan untuk menyambungkan beban, seperti pembesar suara, fon kepala, dsb. manakala antara muka masuk secara amnya mewakili antara muka input talian sumber audio, yang digunakan untuk menyambungkan pemain CD, mudah alih telefon, pemain MP3, komputer, dsb.

Cara menggunakan fungsi File.Exists dalam C# untuk menentukan sama ada fail wujud Dalam operasi fail C#, menentukan sama ada fail wujud ialah keperluan fungsian asas. Fungsi File.Exists ialah kaedah dalam C# yang digunakan untuk menentukan sama ada fail wujud. Artikel ini akan memperkenalkan cara menggunakan fungsi File.Exists dalam C# untuk menentukan sama ada fail wujud dan memberikan contoh kod khusus. Rujuk ruang nama Sebelum anda mula menulis kod, anda perlu merujuk ruang nama System.IO terlebih dahulu, yang

Sesetengah pengguna melaporkan bahawa selepas memasang patch kemas kini Mac Win11 Microsoft KB5035853, ralat kematian skrin biru berlaku, dengan "ThreadStuckinDeviceDriver" dipaparkan pada halaman sistem. Difahamkan bahawa ralat ini mungkin disebabkan oleh masalah perkakasan atau pemandu. Berikut ialah lima pembetulan yang diharapkan dapat menyelesaikan masalah skrin biru komputer anda dengan cepat. Kaedah 1: Jalankan semakan fail sistem. Jalankan perintah [sfc/scannow] dalam gesaan arahan, yang boleh digunakan untuk mengesan dan membaiki isu integriti fail sistem. Tujuan arahan ini adalah untuk mengimbas dan membaiki sebarang fail sistem yang hilang atau rosak, membantu memastikan kestabilan sistem dan operasi normal. Kaedah 2: 1. Muat turun dan buka "Alat Pembaikan Skrin Biru"

Perbezaan antara Mysqlon, dalam, sebagai, di mana Jawapan: Di mana keadaan pertanyaan, gunakan pada untuk sambungan dalaman dan luaran, sebagai alias, untuk bertanya sama ada nilai tertentu mencipta 2 jadual dalam keadaan tertentu: pelajar, pelajar skor: skor: whereSELECT*FROMstudentWHEREs_sex=' Male'Contohnya: onSELECT*FROMstudentLEFTJOINscoreonstudent.s_id=score.s_id gabungan pada dan di mana: SELECT*FROMstudentLEFTJOINs;

Linux ialah sistem pengendalian yang berkuasa dengan banyak arahan dan petua berguna untuk membantu anda menggunakannya dengan lebih cekap. 1. Semak nilai semakan fail Semasa penyalinan atau proses penghantaran, fail mungkin rosak atau diubah suai Dalam kes ini, nilai semakan boleh digunakan untuk pengesahan. Biasanya, kami perlu menggunakan beberapa program antara muka yang disediakan oleh pasukan lain dalam kerja kami. Setiap kali keputusan berjalan program ini tidak seperti yang diharapkan, kami akan membandingkan nilai semakan md5 kedua-dua pihak untuk mengesahkan ketekalan data. Terdapat banyak cara untuk menjana nilai semakan fail yang biasa digunakan termasuk semakan md5sum, semakan crc, semakan jumlah, dll. Perintahnya ialah: fail parameter algoritma md5sumfile_namecksumfile_namesum

Dalam pembangunan sebenar, sokongan berbilang bahasa untuk laman web atau aplikasi telah menjadi ciri yang diperlukan. Sebagai rangka kerja JavaScript yang popular, Vue juga menyokong berbilang bahasa. Artikel ini akan memperkenalkan butiran skema dan pelaksanaan pemprosesan berbilang bahasa dalam Vue. Pemilihan Penyelesaian Terdapat banyak penyelesaian sokongan berbilang bahasa, termasuk tetapi tidak terhad kepada yang berikut: 1.1 Pelaksanaan bersepadu bahagian hadapan bagi fungsi berbilang bahasa pada bahagian hadapan, disokong melalui pemalam vue-i18n. Memperkenalkan pek bahasa yang sepadan sebagai komponen bebas boleh memaparkan yang berbeza

CakePHP ialah rangka kerja PHP sumber terbuka yang menyokong integrasi pengantarabangsaan berbilang bahasa (i18n). i18n boleh menjadikan aplikasi anda berbilang bahasa, menjadikannya lebih mudah untuk anda menarik khalayak antarabangsa dan memberi perkhidmatan yang lebih baik kepada pengguna tempatan. Dalam artikel ini, kita akan melihat secara mendalam tentang penggunaan CakePHPi18n. Bermula Pertama, anda perlu mendayakan keupayaan berbilang bahasa CakePHP. Untuk melakukan ini, kemas kini fail konfigurasi config/bootstrap.php dan tambah kod berikut pada aplikasi anda
