子查詢的概念

1. 子查詢的概念

1.1 子查詢的概念和理解

某些查詢邏輯中县遣,需要引入另一個查詢做為條件或者數(shù)據(jù)來源進行輔助臂痕。
比如:查詢與‘TOM’在同一部門工作的其他員工

select * from emp where deptno = TOM的deptno and ename <> 'TOM';

TOM的deptno

select deptno from emp where ename = 'TOM';

將兩個獨立的查詢合并起來

select * from emp 
where deptno = (select deptno from emp where ename = 'TOM')
and ename <> 'TOM';

整個外部這部分SQL語句被稱為外部查詢(主查詢)讳窟,括號內查詢TOM部門號的這個SQL語句被稱為子查詢

image
1.2 子查詢使用位置

子查詢可以使用在很多子句中

  • from子句中,from子句中的子查詢可以理解為是一張臨時的“表”(視圖)
  • where子句中
  • having子句中
    通常主要使用在where和from中

2. 簡單子查詢(單行子查詢)

單行子查詢的查詢結果是一行一列的數(shù)據(jù)
可以使用常規(guī)的> ,<, >=, <=, =, !=進行子查詢數(shù)據(jù)的比較
可以將子查詢理解為就是一個簡單的數(shù)據(jù)
示例1:查詢比TOM月薪高的員工信息

select * from emp where sal > (select sal from emp where ename = 'TOM')

image

示例2:查詢與LEE是同一職位同一部門的其他員工信息

select *
from emp
where job = (select job from emp where ename = 'LEE') 
and deptno = (select deptno from emp where ename = 'LEE')
and ename <> 'LEE'

image

子查詢中可以嵌套其他的子查詢茂浮,層數(shù)限制在32層內
示例3:查詢月薪高于AMY所在部門平均月薪的員工信息

select *
from emp
where sal > (select AVG(sal) from emp 
         where deptno = (select deptno from emp where ename = 'AMY'))

image

3. 多行子查詢

3.1 多行子查詢

多行子查詢返回的是多行一列的數(shù)據(jù)
當子查詢返回多行記錄時菌羽,使用=這類的比較運算符無法執(zhí)行

image

當有多條記錄返回時,使用IN來進行比較哮塞,相當于等于子查詢中某個值即可
示例4: 查詢是經(jīng)理的員工信息(=)

select *
from emp
where empno in (select distinct mgr from emp where mgr is not null)

image

示例5: 查詢不是經(jīng)理的員工信息(!=)

select *
from emp
where empno not in (select distinct mgr from emp where mgr is not null)

image

not in中的數(shù)據(jù)不能有null值刨秆,如果有null值,相當于執(zhí)行了=null操作忆畅,不能篩選出任何數(shù)據(jù)

3.2 ANY(SOME)與ALL

主要使用在多行子查詢中進行>或<與操作時
ANY(SOME): 任何一個
ALL: 所有

ANY 比最小的大
ALL 比最大的大
< ANY 比最大的小
< ALL 比最小的小

image

示例6:查詢比10部門所有人月薪都要高的員工信息

select *
from emp
where sal > ALL(select sal from emp where deptno = 10)

也可以使用

select *
from emp
where sal > (select MAX(sal) from emp where deptno = 10)

image

使用ANY和ALL執(zhí)行效率要高于分組函數(shù)

3.3 from子句中的子查詢

將子查詢運用在from中衡未,相當于一張“表”
必須為作為“表”的子查詢起“表別名”(示例7中的t)
示例7:查詢部門編號尸执,部門名稱,部門loc缓醋,部門人數(shù)

select d.deptno,d.dname,d.loc,IFNULL(t.empnum,0)
from dept d left join
    (select deptno, COUNT(empno) as empnum
    from emp
    where deptno is not null
    group by deptno) t
     on(d.deptno = t.deptno) 

image

在MySQL中,update語句分組函數(shù)的結果不能作為子查詢的返回結果

update emp set sal = sal + 200
where sal < (select avg(sal) from emp);

MySQL中認為更新和子查詢不能同時進行如失。
解決辦法:將子查詢再次進行嵌套,制作成From中的子查詢

update emp set sal = sal + 200
where sal < (select asal from(select avg(sal) from emp) t);

4. 相關子查詢(難點)

前3節(jié)的子查詢都屬于獨立子查詢送粱,子查詢可以獨立執(zhí)行
相關子查詢:子查詢不可獨立執(zhí)行褪贵,必須依賴外部查詢

4.1 常規(guī)的相關子查詢

示例8:查詢比自己所在部門平均月薪高的員工信息
常規(guī)寫法

select * from emp e
      join (select deptno, AVG(sal) as asal
        from emp
        group by deptno) t
      on(e.deptno = t.deptno)
where e.sal > t.asal

相關子查詢寫法

select * from emp e1
where e1.sal > (select AVG(sal) from emp e2 where e2.deptno = e1.deptno)

image

相關子查詢的特點:外部查詢執(zhí)行一行數(shù)據(jù),子查詢執(zhí)行一次

image
4.2 EXIST關鍵字

子查詢用于驗證外部查詢的一行記錄是否符合子查詢的條件
示例9: 查詢是經(jīng)理的員工的員工信息

select *
from emp e1
where exists (select empno from emp e2 where e2.mgr = e1.empno)

image
image

如果想表述不存在的邏輯抗俄,使用NOT EXISTS

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末脆丁,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子动雹,更是在濱河造成了極大的恐慌槽卫,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,406評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件胰蝠,死亡現(xiàn)場離奇詭異歼培,居然都是意外死亡,警方通過查閱死者的電腦和手機茸塞,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,395評論 3 398
  • 文/潘曉璐 我一進店門躲庄,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人钾虐,你說我怎么就攤上這事噪窘。” “怎么了禾唁?”我有些...
    開封第一講書人閱讀 167,815評論 0 360
  • 文/不壞的土叔 我叫張陵效览,是天一觀的道長。 經(jīng)常有香客問我荡短,道長丐枉,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,537評論 1 296
  • 正文 為了忘掉前任掘托,我火速辦了婚禮瘦锹,結果婚禮上,老公的妹妹穿的比我還像新娘闪盔。我一直安慰自己弯院,他們只是感情好,可當我...
    茶點故事閱讀 68,536評論 6 397
  • 文/花漫 我一把揭開白布泪掀。 她就那樣靜靜地躺著听绳,像睡著了一般。 火紅的嫁衣襯著肌膚如雪异赫。 梳的紋絲不亂的頭發(fā)上椅挣,一...
    開封第一講書人閱讀 52,184評論 1 308
  • 那天头岔,我揣著相機與錄音,去河邊找鬼鼠证。 笑死峡竣,一個胖子當著我的面吹牛,可吹牛的內容都是我干的量九。 我是一名探鬼主播适掰,決...
    沈念sama閱讀 40,776評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼荠列!你這毒婦竟也來了类浪?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 39,668評論 0 276
  • 序言:老撾萬榮一對情侶失蹤肌似,失蹤者是張志新(化名)和其女友劉穎戚宦,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體锈嫩,經(jīng)...
    沈念sama閱讀 46,212評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 38,299評論 3 340
  • 正文 我和宋清朗相戀三年垦搬,在試婚紗的時候發(fā)現(xiàn)自己被綠了呼寸。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,438評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡猴贰,死狀恐怖对雪,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情米绕,我是刑警寧澤瑟捣,帶...
    沈念sama閱讀 36,128評論 5 349
  • 正文 年R本政府宣布,位于F島的核電站栅干,受9級特大地震影響迈套,放射性物質發(fā)生泄漏。R本人自食惡果不足惜碱鳞,卻給世界環(huán)境...
    茶點故事閱讀 41,807評論 3 333
  • 文/蒙蒙 一桑李、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧窿给,春花似錦贵白、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,279評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至角撞,卻和暖如春呛伴,著一層夾襖步出監(jiān)牢的瞬間勃痴,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,395評論 1 272
  • 我被黑心中介騙來泰國打工磷蜀, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留召耘,地道東北人。 一個月前我還...
    沈念sama閱讀 48,827評論 3 376
  • 正文 我出身青樓褐隆,卻偏偏與公主長得像污它,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子庶弃,可洞房花燭夜當晚...
    茶點故事閱讀 45,446評論 2 359

推薦閱讀更多精彩內容

  • 1. 子查詢的概念 1.1 子查詢的概念和理解 某些查詢邏輯中歇攻,需要引入另一個查詢做為條件或者數(shù)據(jù)來源進行輔助固惯。比...
    6969李小甜兒閱讀 424評論 0 0
  • ### 1\. 子查詢的概念 ##### 1.1 子查詢的概念和理解 某些查詢邏輯中,需要引入另一個查詢做為條件或...
    lbon閱讀 284評論 0 0
  • 1. 子查詢的概念 1.1 子查詢的概念和理解 某些查詢邏輯中缴守,需要引入另一個查詢做為條件或者數(shù)據(jù)來源進行輔助葬毫。比...
    陳忠赫閱讀 244評論 0 0
  • 1. 子查詢的概念 1.1 子查詢的概念和理解 某些查詢邏輯中,需要引入另一個查詢做為條件或者數(shù)據(jù)來源進行輔助屡穗。比...
    夜白從來都是一個人閱讀 641評論 0 0
  • 1. 子查詢的概念 1.1 子查詢的概念和理解 某些查詢邏輯中贴捡,需要引入另一個查詢做為條件或者數(shù)據(jù)來源進行輔助。比...
    叮丁boom閱讀 102評論 0 0