子查詢

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閱讀 218,607評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件居凶,死亡現(xiàn)場離奇詭異虫给,居然都是意外死亡,警方通過查閱死者的電腦和手機侠碧,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,239評論 3 395
  • 文/潘曉璐 我一進店門抹估,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人舆床,你說我怎么就攤上這事棋蚌。” “怎么了挨队?”我有些...
    開封第一講書人閱讀 164,960評論 0 355
  • 文/不壞的土叔 我叫張陵谷暮,是天一觀的道長。 經(jīng)常有香客問我盛垦,道長湿弦,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,750評論 1 294
  • 正文 為了忘掉前任腾夯,我火速辦了婚禮颊埃,結果婚禮上,老公的妹妹穿的比我還像新娘蝶俱。我一直安慰自己班利,他們只是感情好,可當我...
    茶點故事閱讀 67,764評論 6 392
  • 文/花漫 我一把揭開白布榨呆。 她就那樣靜靜地躺著罗标,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上闯割,一...
    開封第一講書人閱讀 51,604評論 1 305
  • 那天彻消,我揣著相機與錄音,去河邊找鬼宙拉。 笑死宾尚,一個胖子當著我的面吹牛,可吹牛的內容都是我干的谢澈。 我是一名探鬼主播煌贴,決...
    沈念sama閱讀 40,347評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼锥忿!你這毒婦竟也來了崔步?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 39,253評論 0 276
  • 序言:老撾萬榮一對情侶失蹤缎谷,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后灶似,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體列林,經(jīng)...
    沈念sama閱讀 45,702評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,893評論 3 336
  • 正文 我和宋清朗相戀三年酪惭,在試婚紗的時候發(fā)現(xiàn)自己被綠了希痴。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,015評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡春感,死狀恐怖砌创,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情鲫懒,我是刑警寧澤嫩实,帶...
    沈念sama閱讀 35,734評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站窥岩,受9級特大地震影響甲献,放射性物質發(fā)生泄漏。R本人自食惡果不足惜颂翼,卻給世界環(huán)境...
    茶點故事閱讀 41,352評論 3 330
  • 文/蒙蒙 一晃洒、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧朦乏,春花似錦球及、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,934評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春际歼,著一層夾襖步出監(jiān)牢的瞬間惶翻,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,052評論 1 270
  • 我被黑心中介騙來泰國打工鹅心, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留吕粗,地道東北人。 一個月前我還...
    沈念sama閱讀 48,216評論 3 371
  • 正文 我出身青樓旭愧,卻偏偏與公主長得像颅筋,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子输枯,可洞房花燭夜當晚...
    茶點故事閱讀 44,969評論 2 355

推薦閱讀更多精彩內容

  • 1. 子查詢的概念 1.1 子查詢的概念和理解 某些查詢邏輯中议泵,需要引入另一個查詢做為條件或者數(shù)據(jù)來源進行輔助。比...
    夜白從來都是一個人閱讀 634評論 0 0
  • 1. 子查詢的概念 1.1 子查詢的概念和理解 某些查詢邏輯中桃熄,需要引入另一個查詢做為條件或者數(shù)據(jù)來源進行輔助先口。比...
    上仙_8e6b閱讀 239評論 0 1
  • 1. 子查詢的概念 1.1 子查詢的概念和理解 某些查詢邏輯中,需要引入另一個查詢做為條件或者數(shù)據(jù)來源進行輔助瞳收。比...
    叮丁boom閱讀 100評論 0 0
  • 1. 子查詢的概念 1.1 子查詢的概念和理解 某些查詢邏輯中碉京,需要引入另一個查詢做為條件或者數(shù)據(jù)來源進行輔助。比...
    yangsg閱讀 1,253評論 0 8
  • 我不會莫名的哭泣螟深,只是猶疑谐宙,26年的歲月里有那么多美好回憶,總在不經(jīng)意想起界弧,是你凡蜻,是你,難以忘記垢箕,卻早已消失在人海...
    夢凝雪天閱讀 184評論 0 0