當前位置:首頁 » 編程語言 » sql查詢in

sql查詢in

發布時間: 2022-06-08 19:06:29

sql語句中 in和or的區別

SQL語句中 in和or的區別為:操作不同、適合不同、執行效率不同。

一、操作不同

1、in:in是把父查詢表和子查詢表作hash連接。

2、or:or是對父查詢表作loop循環,每次loop循環再對子查詢表進行查詢。

二、適合不同

1、in:in適合用於子查詢表數據比父查詢表數據多的情況。

2、or:or適合用於子查詢表數據比父查詢表數據少的情況。

三、執行效率不同

1、in:在沒有索引的情況下,隨著in後面的數據量越多,in的執行效率不會有太大的下降。

2、or:在沒有索引的情況下,隨著or後面的數據量越多,or的執行效率會有明顯的下降。

❷ SQL查詢中in和exists有什麼區別

1.exist,not exist一般都是與子查詢一起使用. In可以與子查詢一起使用,也可以直接in (a,b.....)

2.exist會針對子查詢的表使用索引. not exist會對主子查詢都會使用索引. in與子查詢一起使用的時候,只能針對主查詢使用索引. not in則不會使用任何索引. 注意,一直以來認為exists比in效率高的說法是不準確的。
in 是把外表和內表作hash 連接,而exists是對外表作loop循環,每次loop循環再對內表進行查詢。
如果查詢的兩個表大小相當,那麼用in和exists差別不大。
如果兩個表中一個較小,一個是大表,則子查詢表大的用exists,子查詢表小的用in:
例如:表A(小表),表B(大表)1:select * from A where cc in (select cc from B)
效率低,用到了A表上cc列的索引;select * from A where exists(select cc from B where cc=A.cc)
效率高,用到了B表上cc列的索引。
相反的2:select * from B where cc in (select cc from A)
效率高,用到了B表上cc列的索引;select * from B where exists(select cc from A where cc=B.cc)
效率低,用到了A表上cc列的索引。
not in 和not exists如果查詢語句使用了not in 那麼內外表都進行全表掃描,沒有用到索引;而not extsts 的子查詢依然能用到表上的索引。所以無論那個表大,用not exists都比not in要快。
3.exist與in都可以實現一個目的.二者都可以用來過濾數據.
示例:

select count(1) from t1;--160W
select count(1) from t2; --90W

SELECT count(1)
FROM t1 a
WHERE EXISTS (SELECT accountid
FROM t2 b
WHERE a.keyid = b.keyid AND a.ideaid = b.ideaid);--主大子小,不適合使用exist,因為exist只會利用子表t2的復合索引keyid+ideaid,而子表內容要小與主表,主表由於無法使用索引,查詢效率低下.

select count(1) from t1 a where accountid in (SELECT accountid
FROM t2 b
WHERE a.keyid = b.keyid AND a.ideaid = b.ideaid);--主大子小,適合用in,因為in只會使用主表t1裡面的復合主鍵keyid-ideaid,在主表大於子表的情況下,會很好的利用主表的索引.

--後二條sql的執行結果都是一樣的.說明exist與in在用法上可以達到一個目的,不同的地方是
--1.性能的考慮此時就按子表大主表小用exist,子表小主表大用in的原則就可以.
--2.寫法的不同, exist的where條件是: "...... where exist (..... where a.id=b.id)"
--in的where條件是: " ...... where id in ( select id .... where a.id=b.id)"

4. exist的原理:
exists做為where 條件時,是先對where 前的主查詢詢進行查詢,然後用主查詢的結果一個一個的代入exists的查詢進行判斷,如果為真則輸出當前這一條主查詢的結果,否則不輸出
比如
如下:
表A
ID NAME
1 A1
2 A2
3 A3

表B
ID AID NAME
1 1 B1
2 2 B2
3 2 B3

表A和表B是一對多的關系 A.ID --> B.AID

SELECT ID , NAME FROM A WHERE EXISTS (SELECT * FROM B WHERE A.ID = B.AID)
執行結果為
1 A1
2 A2
原因可以按照如下分析
SELECT ID , NAME FROM A WHERE EXISTS (SELECT * FROM B WHERE B.AID = 1)
-->SELECT * FROM B WHERE B.AID = 1有值返回真所以有數據

SELECT ID , NAME FROM A WHERE EXISTS (SELECT * FROM B WHERE B.AID = 2)
-->SELECT * FROM B WHERE B.AID = 2有值返回真所以有數據

SELECT ID , NAME FROM A WHERE EXISTS (SELECT * FROM B WHERE B.AID = 3)
-->SELECT * FROM B WHERE B.AID = 3無值返回真所以沒有數據

NOT EXISTS 就是反過來
SELECT ID , NAME FROM A WHERE NOT EXIST (SELECT * FROM B WHERE A.ID = B.AID)
執行結果為
3 A3
5. in 與 =的區別
select name from student where name in ('zhang','wang','li','zhao');

select name from student where name='zhang' or name='li' or name='wang' or name='zhao'
的結果是相同的。
in的欄位也可以與其它欄位建復合索引.
比如
T1包含下面key, accountd,groupid.

SELECT *
FROM T1 a
WHERE a.groupid = 2001
AND a.accountid = 1001
AND a.key IN ('abc', 'def', 'ala');

--上面的sql可以將accountid,key建成復合索引.

❸ sql條件in三個sql的查詢結果

你沒寫具體內容不好判斷,不過一般來說是兩種情況。
(1)三個sql取交集,這種情況下用and就可以,也就是滿足第一個sql的同時滿足第二個sql,而且還滿足第三個sql。
where 欄位 in(sql1) and 欄位 in(sql2) and 欄位 in(sql2)
(2)三個sql是並集的關系,那麼用or就可以,要麼滿足第一個,要麼第二個,要麼第三個。
where 欄位 in(sql1) or 欄位 in (sql2) or 欄位 in(sql3)
當然如果有什麼特殊的,那就不好說了。

❹ sql語句中in的用法

IN 操作符允許我們在 WHERE 子句中規定多個值。

SQL IN 語法:

SELECT column_name(s)

FROM table_name

WHERE column_name IN (value1,value2,...)

(4)sql查詢in擴展閱讀:

1、IN 與 = ANY 等價,均表示,變數在(子查詢)列表之中,即 a IN (table B) 表示 a = ANY B.b

2、NOT IN 與 <> ALL 等價,而不等於<> ANY,前兩者均表示,變數不在(子查詢)列表之中,即 a NOT IN (table B) 表示 a <> ALL B.b。而如果a <> ANY B.b,則只要任意一個b<>a就true了。

3、IN 與 EXISTS 的性能區別主要來自,IN 會編列子查詢的每行記錄,然後再返回,而EXISTS 則只要遇到第一個滿足條件的記錄就馬上返回。

❺ SQL in查詢語句

資料庫中有一個pzdz
這是個欄位嗎?
裡面的是數字組成的字元串
是這種格式嗎?
pzdz
1,3,5,2
3,6,15,17
select
*
from
table
where
pzdz
like('aa,%')
or
pzdz
like('%,aa')
or
pzdz
like('%,aa,%')
or
pzdz='aa';
考慮到了
pzdz
...,aa,...
aa,...
....,aa
aa
四種情況
笨辦法
有區別的
你測試吧

❻ sql in語句是什麼呢

sql in語句的用法具體指的就是在結構化查詢語言這樣子的編程語言裡面所應用的一些跟in相關的一些語句的,然後在裡面的話主要就是有用到查詢匹配多個欄位這樣子的一個過程的。


比如select in就能夠以關鍵字去查詢匹配單個欄位,然後用相關的一段代碼就能夠實現這樣子的一個過程,然後select in關鍵字還能夠查詢匹配多個欄位的。

並且在這樣子的一個SQL的語句裡面,通常就是要去搭配各種不同的語法,然後就能夠實現各種不同的過程的。比如把檢索的表的名字或者是列的名字進行更改,就能夠實現一個不同的過程,所以這就是在SQL語句裡面in語句的一個含義。

❼ sql中in和exist語句的區別

兩者都能實現表功能查詢,主要區別如下:

1、適用表的類型不同。

in是子查詢為驅動表,外面的表為被驅動表,故適用於子查詢結果集小而外面的表結果集大的情況。

exists是外面的表位驅動表,子查詢裡面的表為被驅動表,故適用於外面的表結果集小而子查詢結果集大的情況。

2、子查詢關聯不同。

exists一般都是關聯子查詢。對於關聯子查詢,必須先執行外層查詢,接著對所有通過過濾條件的記錄,執行內層查詢。外層查詢和內層查詢相互依賴,因為外層查詢會把數據傳遞給內層查詢。

in則一般都是非關聯子查詢,非關聯子查詢則必須先完成內層查詢之後,外層查詢才能介入。

3、執行次數不同。

IN 語句:只執行一次,確定給定的值是否與子查詢或列表中的值相匹配。in在查詢的時候,首先查詢子查詢的表,然後將內表和外表做一個笛卡爾積,然後按照條件進行篩選。所以相對內表比較小的時候,in的速度較快。

EXISTS語句:執行次數根據表的長度而定。指定一個子查詢,檢測行的存在。遍歷循環外表,然後看外表中的記錄有沒有和內表的數據一樣的。匹配上就將結果放入結果集中。

❽ in在sql中是什麼意思

select * from table where id in (1,3,5)
查詢表裡 id 是1 或者3 或者5 的記錄
select * from table where name in ('小明','小紅','小麗')
查詢表裡 name 等於 小明 或者小紅 或者 小麗的記錄
還有not in

熱點內容
手機電量緩存 發布:2025-02-08 09:01:37 瀏覽:898
java怎麼寫程序 發布:2025-02-08 09:00:55 瀏覽:868
javaphp加密 發布:2025-02-08 08:59:45 瀏覽:986
股票避險資產配置哪個好 發布:2025-02-08 08:57:44 瀏覽:878
谷歌瀏覽器開啟ftp 發布:2025-02-08 08:55:08 瀏覽:31
安卓工程師開發是什麼專業 發布:2025-02-08 08:38:15 瀏覽:678
怎麼用電腦和朋友遠程伺服器連接 發布:2025-02-08 08:29:52 瀏覽:233
如何播放咪咕視頻的緩存電影 發布:2025-02-08 08:28:17 瀏覽:574
台式電腦修改密碼在哪裡修改 發布:2025-02-08 08:25:18 瀏覽:298
linux編譯opencv 發布:2025-02-08 08:14:29 瀏覽:713