子查詢

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語句被稱為外部查詢(主查詢),括號內(nèi)查詢TOM部門號的這個SQL語句被稱為子查詢

image
1.2 子查詢使用位置

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

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

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

單行子查詢的查詢結(jié)果是一行一列的數(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層內(nèi)
示例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ù)的結(jié)果不能作為子查詢的返回結(jié)果

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. 相關(guān)子查詢(難點)

前3節(jié)的子查詢都屬于獨立子查詢痢掠,子查詢可以獨立執(zhí)行
相關(guān)子查詢:子查詢不可獨立執(zhí)行,必須依賴外部查詢

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

示例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

相關(guān)子查詢寫法

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

image

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

image
4.2 EXIST關(guān)鍵字

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

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

image
image

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

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市佃牛,隨后出現(xiàn)的幾起案子淹辞,更是在濱河造成了極大的恐慌,老刑警劉巖俘侠,帶你破解...
    沈念sama閱讀 219,366評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件桑涎,死亡現(xiàn)場離奇詭異,居然都是意外死亡兼贡,警方通過查閱死者的電腦和手機攻冷,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,521評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來遍希,“玉大人等曼,你說我怎么就攤上這事。” “怎么了禁谦?”我有些...
    開封第一講書人閱讀 165,689評論 0 356
  • 文/不壞的土叔 我叫張陵胁黑,是天一觀的道長。 經(jīng)常有香客問我州泊,道長丧蘸,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,925評論 1 295
  • 正文 為了忘掉前任遥皂,我火速辦了婚禮力喷,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘演训。我一直安慰自己弟孟,他們只是感情好,可當我...
    茶點故事閱讀 67,942評論 6 392
  • 文/花漫 我一把揭開白布样悟。 她就那樣靜靜地躺著拂募,像睡著了一般。 火紅的嫁衣襯著肌膚如雪窟她。 梳的紋絲不亂的頭發(fā)上陈症,一...
    開封第一講書人閱讀 51,727評論 1 305
  • 那天,我揣著相機與錄音震糖,去河邊找鬼录肯。 笑死,一個胖子當著我的面吹牛试伙,可吹牛的內(nèi)容都是我干的嘁信。 我是一名探鬼主播,決...
    沈念sama閱讀 40,447評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了糙俗?” 一聲冷哼從身側(cè)響起栽渴,我...
    開封第一講書人閱讀 39,349評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,820評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡单寂,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,990評論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了吐辙。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片宣决。...
    茶點故事閱讀 40,127評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖昏苏,靈堂內(nèi)的尸體忽然破棺而出尊沸,到底是詐尸還是另有隱情威沫,我是刑警寧澤,帶...
    沈念sama閱讀 35,812評論 5 346
  • 正文 年R本政府宣布洼专,位于F島的核電站棒掠,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏屁商。R本人自食惡果不足惜烟很,卻給世界環(huán)境...
    茶點故事閱讀 41,471評論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望蜡镶。 院中可真熱鬧雾袱,春花似錦、人聲如沸帽哑。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,017評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽妻枕。三九已至,卻和暖如春粘驰,著一層夾襖步出監(jiān)牢的瞬間屡谐,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,142評論 1 272
  • 我被黑心中介騙來泰國打工蝌数, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留愕掏,地道東北人。 一個月前我還...
    沈念sama閱讀 48,388評論 3 373
  • 正文 我出身青樓顶伞,卻偏偏與公主長得像饵撑,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子唆貌,可洞房花燭夜當晚...
    茶點故事閱讀 45,066評論 2 355

推薦閱讀更多精彩內(nèi)容

  • 1. 子查詢的概念 1.1 子查詢的概念和理解 某些查詢邏輯中滑潘,需要引入另一個查詢做為條件或者數(shù)據(jù)來源進行輔助。比...
    夜白從來都是一個人閱讀 638評論 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
  • 工具:Xcode7.2.1 骂倘、 Unity3D5.3.6f1 personal眼滤、 測試機:iphone5/iOS8...
    GanGai閱讀 634評論 0 0