全文大約【1258】字,不說(shuō)廢話(huà),只講可以讓你學(xué)到技術(shù)、明白原理的純干貨!本文帶有豐富案例及配圖視頻,讓你更好的理解和運(yùn)用文中的技術(shù)概念,并可以給你帶來(lái)具有足夠啟迪的思考......
一. 子查詢(xún)
什么是子查詢(xún)呢?小編來(lái)為各位小伙伴細(xì)細(xì)道來(lái)。所謂子查詢(xún)就是將一個(gè)查詢(xún)結(jié)果作為判斷條件或者作為一張?zhí)摂M表在這個(gè)結(jié)果的基礎(chǔ)上進(jìn)行另一個(gè)查詢(xún)。
1.子查詢(xún)(作為條件判斷)
下面就是將查詢(xún)結(jié)果作為另一個(gè)查詢(xún)的判斷條件。
語(yǔ)法 : SELECT 列名 FROM 表名 Where 條件 (子查詢(xún)結(jié)果)
舉個(gè)栗子:查詢(xún)和小編同歲的其他同學(xué)。
#1.先查詢(xún)到小編的年齡
select Sage from student where Sname='小編'; #年齡是12
#2.查詢(xún)年齡等于小編年齡的同學(xué)
select * from student where Sage=12;
#3.將 1、2 兩條語(yǔ)句整合
select * from student where Sage=(select Sage from student where Sname='小編');
注意 :將子查詢(xún) ”一行一列“的結(jié)果作為外部查詢(xún)的條件,做第二次查詢(xún)子查詢(xún)得到一行一列的結(jié)果才能作為外部查詢(xún)的等值判斷條件或不等值條件判斷。
2.子查詢(xún)(作為枚舉查詢(xún)條件)
子查詢(xún)作為枚舉查詢(xún)條件使用是將一個(gè)查詢(xún)結(jié)果(單列多行)的結(jié)果集作為枚舉查詢(xún)條件進(jìn)行二次查詢(xún)。
語(yǔ)法 :SELECT 列名 FROM 表名 Where 列名 in(子查詢(xún)結(jié)果);
舉個(gè)栗子:查詢(xún)和小編,小編哥同齡的學(xué)生信息。
#1. 先查詢(xún)小編和小編哥的年齡(多行單列)
select Sage from student where Sname in('健哥', '小編哥'); #年齡是12和23
#2. 再查詢(xún)年齡為12和23的學(xué)員信息
select * from student where Sage in(12, 23);
#3.SQL:合并
select * from student where Sage in(select Sage from student where Sname in('小編', '小編哥'));
將子查詢(xún) ”多行一列“的結(jié)果作為外部查詢(xún)的枚舉查詢(xún)條件,做第二次查詢(xún)。
3.子查詢(xún)(作為一張表)
此處小編敲黑板啦!非常重要,使用頻率很高!
下面的子查詢(xún)是將一個(gè)查詢(xún)的結(jié)果當(dāng)做一張?zhí)摂M表,然后在這個(gè)表的結(jié)果基礎(chǔ)上再進(jìn)行查詢(xún)。
語(yǔ)法 :SELECT 列名 FROM (子查詢(xún)的結(jié)果集) WHERE 條件;
舉個(gè)栗子:查詢(xún)最老的5名學(xué)生信息。
#思路:
#1. 先對(duì)學(xué)生年齡排序查詢(xún)(排序后的臨時(shí)表)
select * from student order by Sage desc;
#2. 再查詢(xún)臨時(shí)表中前5行學(xué)生信息
select *
from (臨時(shí)表)
limit 0,5;
#SQL:合并
select * from (
select * from student order by Sage desc
) as temp limit 0,4;
將子查詢(xún) ”多行多列“的結(jié)果作為外部查詢(xún)的一張表,做第二次查詢(xún)。
注意:子查詢(xún)作為臨時(shí)表,為其賦予一個(gè)臨時(shí)表名。
二. 結(jié)語(yǔ)
小編在這里對(duì)本文核心要點(diǎn)進(jìn)行總結(jié):
子查詢(xún)有三種使用場(chǎng)景分別是:子查詢(xún)結(jié)果作為判斷條件、子查詢(xún)結(jié)果作為枚舉條件、子查詢(xún)結(jié)果作為一個(gè)虛擬表進(jìn)行二次查詢(xún)。