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