千鋒教育-做有情懷、有良心、有品質的職業(yè)教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > 什么是MySQL子查詢

什么是MySQL子查詢

來源:千鋒教育
發(fā)布人:zyh
時間: 2023-06-13 13:23:00 1686633780

  全文大約【1258】字,不說廢話,只講可以讓你學到技術、明白原理的純干貨!本文帶有豐富案例及配圖視頻,讓你更好的理解和運用文中的技術概念,并可以給你帶來具有足夠啟迪的思考......

什么是MySQL子查詢

  一. 子查詢

  什么是子查詢呢?小編來為各位小伙伴細細道來。所謂子查詢就是將一個查詢結果作為判斷條件或者作為一張?zhí)摂M表在這個結果的基礎上進行另一個查詢。

  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='小編');

1683543033245.image


  注意 :將子查詢 ”一行一列“的結果作為外部查詢的條件,做第二次查詢子查詢得到一行一列的結果才能作為外部查詢的等值判斷條件或不等值條件判斷。

  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('小編', '小編哥'));

1683543059871.image

  將子查詢 ”多行一列“的結果作為外部查詢的枚舉查詢條件,做第二次查詢。

  3.子查詢(作為一張表)

  此處小編敲黑板啦!非常重要,使用頻率很高!

  下面的子查詢是將一個查詢的結果當做一張?zhí)摂M表,然后在這個表的結果基礎上再進行查詢。

  語法 :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;

1683543087414.image

  將子查詢 ”多行多列“的結果作為外部查詢的一張表,做第二次查詢。

  注意:子查詢作為臨時表,為其賦予一個臨時表名。

  二. 結語

  小編在這里對本文核心要點進行總結:

  子查詢有三種使用場景分別是:子查詢結果作為判斷條件、子查詢結果作為枚舉條件、子查詢結果作為一個虛擬表進行二次查詢。

聲明:本站稿件版權均屬千鋒教育所有,未經(jīng)許可不得擅自轉載。
10年以上業(yè)內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT