SQL SERVER中關于exists 和 in的簡單分析
In與Exists這兩個函數是差不多的,但由于優(yōu)化方案不同,通常NOT Exists要比NOT IN要快,因為NOT EXISTS可以使用結合算法二NOT IN就不行了,而EXISTS則不如IN快,因為這時候IN可能更多的使用結合算法。

如圖,現在有兩個數據集,左邊表示#tempTable1,右邊表示#tempTable2?,F在有以下問題:
1.求兩個集的交集?
2.求tempTable1中不屬于集#tempTable2的集?
先創(chuàng)建兩張臨時表:
create table #tempTable1
(
argument1 nvarchar(50),
argument2 varchar(20),
argument3 datetime,
argument4 int
);
insert into #tempTable1(argument1,argument2,argument3,argument4)
values('preacher001','13023218757',GETDATE()-1,1);
insert into #tempTable1(argument1,argument2,argument3,argument4)
values('preacher002','23218757',GETDATE()-2,2);
insert into #tempTable1(argument1,argument2,argument3,argument4)
values('preacher003','13018757',GETDATE()-3,3);
insert into #tempTable1(argument1,argument2,argument3,argument4)
values('preacher004','13023257',GETDATE()-4,4);
insert into #tempTable1(argument1,argument2,argument3,argument4)
values('preacher005','13023218',GETDATE()-5,5);
insert into #tempTable1(argument1,argument2,argument3,argument4)
values('preacher006','13023218',GETDATE()-6,6);
insert into #tempTable1(argument1,argument2,argument3,argument4)
values('preacher007','13023218',GETDATE()-7,7);
insert into #tempTable1(argument1,argument2,argument3,argument4)
values('preacher008','13023218',GETDATE()-8,8);
create table #tempTable2
(
argument1 nvarchar(50),
argument2 varchar(20),
argument3 datetime,
argument4 int
);
insert into #tempTable2(argument1,argument2,argument3,argument4)
values('preacher001','13023218757',GETDATE()-1,1);
insert into #tempTable2(argument1,argument2,argument3,argument4)
values('preacher0010','23218757',GETDATE()-10,10);
insert into #tempTable2(argument1,argument2,argument3,argument4)
values('preacher003','13018757',GETDATE()-3,3);
insert into #tempTable2(argument1,argument2,argument3,argument4)
values('preacher004','13023257',GETDATE()-4,4);
insert into #tempTable2(argument1,argument2,argument3,argument4)
values('preacher009','13023218',GETDATE()-9,9);
比如,我現在以#tempTable1和#tempTable2的argument1作為參照
1.求兩集的交集:
1)in 方式
select * from #tempTable2 where argument1 in (select argument1 from #tempTable1)
2)exists 方式
select * from #tempTable2 t2 where exists (select * from #tempTable1 t1 where t1.argument1=t2.argument1)

2.求tempTable1中不屬于集#tempTable2的集
1)in 方式
select * from #tempTable1 where argument1 not in (select argument1 from #tempTable2)
2)exists 方式
select * from #tempTable1 t1 where not exists (select * from #tempTable2 t2 where t1.argument1=t2.argument1)

- php數組查找函數in_array()、array_search()、array_key_exists()使用實例
- SQL查詢中in和exists的區(qū)別分析
- sql not in 與not exists使用中的細微差別
- mysql not in、left join、IS NULL、NOT EXISTS 效率問題記錄
- UCenter info: MySQL Query Error SQL:SELECT value FROM [Table]vars WHERE noteexists
- mysql insert if not exists防止插入重復記錄的方法
- Oracle In和exists not in和not exists的比較分析
- MySQL: mysql is not running but lock exists 的解決方法
- sql語句優(yōu)化之用EXISTS替代IN、用NOT EXISTS替代NOT IN的語句
相關文章
SqlServer參數化查詢之where in和like實現詳解
若有一天你不可避免的需要提高SQL的查詢性能,需要一次性where in 幾百、上千、甚至上萬條數據時,參數化查詢將是必然進行的選擇2012-05-05
Microsoft SQLServer的版本區(qū)別及選擇
Microsoft SQLServer的版本區(qū)別及選擇...2007-02-02
SQL?Server數據庫表的創(chuàng)建與管理操作大全
這篇文章主要給大家介紹了關于SQL?Server數據庫表的創(chuàng)建與管理操作的相關資料,?SQL?Server是一個關系型數據庫管理系統(tǒng),它可以幫助用戶創(chuàng)建、管理和查詢數據,文中介紹的非常詳細,需要的朋友可以參考下2024-01-01
SQL SERVER先判斷視圖是否存在然后再創(chuàng)建視圖的語句
SQL SERVER中先判斷視圖是否存在,使用IF NOT EXISTS,然后再創(chuàng)建視圖,使用create view,整個過程如下2014-08-08

