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