黄视频网站在线免费观看-黄视频网站在线看-黄视频网站在线观看-黄视频网站免费看-黄视频网站免费观看-黄视频网站免费

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

手機站
千鋒教育

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

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

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

當前位置:首頁  >  技術干貨  > 如果有子查詢SQL語句的執行順序是怎么樣的?

如果有子查詢SQL語句的執行順序是怎么樣的?

來源:千鋒教育
發布人:xqq
時間: 2023-10-13 19:06:26 1697195186

一、如果有子查詢SQL語句的執行順序是怎么樣的

1、子查詢作為WHERE子句的一部分

子查詢作為WHERE子句的一部分時,首先會執行子查詢,得到結果集后,將該結果集作為條件與外層查詢的表進行比較,只有符合條件的行才會被返回。

例如:

SELECT * FROM table_name WHERE column_name IN (SELECT column_name FROM another_table_name WHERE condition);

此處,子查詢會首先執行,得到結果集,并返回所有滿足條件的列值,然后將這些列值與外層WHERE條件中指定的列值進行比較,只返回那些滿足條件的行。

2、子查詢作為HAVING子句的一部分

子查詢作為HAVING子句的一部分時,首先會對GROUP BY子句所指定的列進行分組,然后再執行子查詢,得到結果集后,將該結果集作為條件與分組后的每個組進行比較,只有符合條件的組才會被返回。

例如:

SELECT column_name FROM table_name GROUP BY column_name HAVING MAX(column_name) > (SELECT column_name FROM another_table_name WHERE condition)

此處,首先會對table_name中的列進行分組,然后在每個組內部執行子查詢,得到結果集,并返回那些最大值大于another_table_name中的列值的組。

3、子查詢作為SELECT子句的一部分

子查詢作為SELECT子句的一部分時,首先會執行子查詢,得到結果集后,將該結果集作為列值加入到外層查詢的結果集中。

例如:

SELECT column_name1, (SELECT column_name2 FROM another_table_name WHERE condition) AS column_name3 FROM table_name;

此處,子查詢會首先執行,得到結果集,并將其作為一列(column_name3)加入到當前查詢結果集中。

二、SQL單表查詢

1、簡介

查詢語句(SELECT)是數據庫中最基本的和最重要的語句之一,其功能是從數據庫中檢索滿足條件的數據。查詢的數據源可以來自一張表,也可以來自多張表甚至來自視圖,查詢的結果是由0行(沒有滿足條件的數據)或多行記錄組成的一個記錄集合,并允許選擇一個或多個字段作為輸出字段。SELECT語句還可以對查詢結果進行排序、匯總等。查詢語句的基本結構可描述為:

SELECT <目標列名序列> -- 需要哪些列
FROM <表名> [JOIN <表名> ON <連接條件>] -- 來自哪些表
[WHERE <行選擇條件>] -- 根據什么條件
[GROUP BY <分組依據列>]
[HAVING <組選擇條件>]
[ORDER BY <排列依據列>]

其中:

SELECT 子句用于指定輸出的字段FROM 子句用于指定數據的來源WHERE 子句用于指定數據的行選擇條件GROUP BY 子句用于對檢索到的記錄進行分組HAVING 子句用于指定對分組后結果的選擇條件ORDER BY 子句用于對查詢的結果進行排序

2、選擇表中若干列

查詢指定的列:

-- 查詢全體學生的學好與姓名
SELECT Sno, Sname FROM Student

查詢全部列:

-- 查詢全體學生的全部信息
SELECT Sno, Sname, Ssex, Sbirthday, Sdept, Memo FROM Student
-- 等價于
SELECT * FROM Student

查詢表中沒有的列:

-- 含表達式的列:查詢全體學生的姓名及年齡(年齡的列名是空)SELECT Sname, YEAR(GETDATE()) - YEAR(Sbirthday) FROM Student-- 查詢全體學生的姓名、年齡、字符串“今年是”以及今年的年份(給列取別名)SELECT Sname 姓名,YEAR(GETDATE()) - YEAR(Sbirthday) 年齡,'今年是' 今年是, YEAR(GETDATE()) 年份FROM Student

3、選擇表中若干行

查詢滿足條件的元組:

-- 1. 比較大小---------------------------------------------- 查詢計算機系所有學生的姓名SELECT Sname FROM Student WHERE Sdept='計算機系'-- 查詢考試成績大于90的學生的學號、課程號和成績SELECT Sno, Cno, Grade FROM SC WHERE Grade > 90-- 2. 確定范圍--------------------------------------------/*注意:BETWEEN ... AND ... :包括邊界NOT BETWEEN ... AND ... :不包括邊界*/-- 查詢學分在2~3之間的課程的課程名稱、學分和開課學期SELECT Cname, Credit, Semester FROM Course WHERE Credit BETWEEN 2 AND 3-- 等價于SELECT Cname, Credit, Semester FROM Course WHERE Credit >= 2 AND Credit <=3-- 查詢學分不在2~3之間的課程的課程名稱、學分和開課學期SELECT Cname, Credit, Semester FROM Course WHERE Credit NOT BETWEEN 2 AND 3-- 等價于SELECT Cname, Credit, Semester FROM CourseWHERE Credit < 2 OR Credit > 3-- 查詢出生在1997年的學生的全部信息SELECT * FROM StudentWHERE Sbirthday BETWEEN '1997-01-01' AND '1997-12-31'-- 3. 確定集合---------------------------------------------- 查詢‘計算機系’和‘機電系’學生的學號、姓名和所在系SELECT Sno, Sname, Sdept FROM StudentWHERE Sdept IN ('計算機系', '機電系')-- 查詢不在‘計算機系’和‘機電系’學生的學號、姓名和所在系SELECT Sno, Sname, Sdept FROM StudentWHERE Sdept NOT IN ('計算機系', '機電系')-- 4. 字符串匹配--------------------------------------------/*匹配串中有如下四種通配符:_:匹配任意一個字符%:匹配0到多個字符[]:匹配[ ]中任意一個字符。如[abcd]表示匹配a, b, c, d中的一個。若要比較的字符是連續的,也可以用連字符'-'表達,比如匹配 abcd中任意一個可寫成 [a-d][^ ]:不匹配[ ]中的任意一個字符,用法與[ ]一致,也可以用'-'表示連續字符*/-- 查詢姓‘李’的學生的學號、姓名和所在系SELECT Sno, Sname, Sdept FROM StudentWHERE Sname LIKE '李%'-- 查詢姓名中第二個字是‘沖’的學生的學號、姓名和所在系SELECT Sno, Sname, Sdept FROM StudentWHERE Sname LIKE '_沖%'-- 查詢學號最后不是‘2’或者‘3’的學生的學號、姓名和所在系SELECT Sno, Sname, Sdept FROM StudentWHERE Sno NOT LIKE '%[23]'/*注:mysql的LIKE好像沒有 []和 [^]的用法,但可以用 REGEXP和 NOT REGEXP來用正則表達式進行匹配*/-- 如mysql下,查詢學號最后不是‘2’或者‘3’的學生的學號、姓名和所在系SELECT Sno, Sname, Sdept FROM Student WHERE Sno NOT REGEXP '[23]$'/*ESCAPE:可以指定一個字符,將該字符后面的一個字符當作普通字符看待,可以用來匹配 '_' 和 '%' 等通配符*/-- 查詢msg字段中包含 "30%" 的記錄WHERE msg LIKE '%30!%%' ESCAPE '!'-- 5. 涉及空值的查詢---------------------------------------------- 查詢還沒有考試的學生的學號、相應的課程號SELECT Sno, Cno FROM SCWHERE Grade IS NULL-- 查詢有備注的學生的學號、姓名和備注SELECT Sno, Sname, Memo FROM StudentWHERE Memo IS NOT NULL-- 6. 多重條件查詢---------------------------------------------- 查詢‘計算機系’有備注的學生的學好、姓名、所在系和備注SELECT Sno, Sname, Sdept, Memo FROM StudentWHERE Memo IS NOT NULL AND Sdelt = '計算機系'-- 查詢 ‘機電系’和‘計算機系’1997年出生的學生的學號、姓名、所在系和生日SELECT Sno, Sname, Sdept, Sbirthday FROM StudentWHERE (Sdept = '計算機系' OR Sdept = '機電系')AND Sbirthday BETWEEN '1997-01-01' AND '1997-12-31'

消除取值相同的行:

/*雖然原關系中不存在兩個完全相同的元組,但經過一定操作后可能會出現相同的元組*/-- 查詢有考試掛科的學生的學號SELECT DISTINCT Sno FROM SCWHERE Grade < 60

延伸閱讀1:SQL語法要求

SQL語句可以單行或多行書寫,以分號結尾;可以用空格和縮進來來增強語句的可讀性;關鍵字不區別大小寫,建議使用大寫。
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師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
韩国毛片| 天堂网中文字幕| 欧美激情一区二区三区在线| 免费一级片在线| 日日夜人人澡人人澡人人看免| 午夜久久网| 91麻豆国产级在线| 在线观看成人网| 成人在免费观看视频国产| 日韩一级精品视频在线观看| 精品在线观看国产| 高清一级淫片a级中文字幕| 国产不卡精品一区二区三区| 91麻豆精品国产综合久久久| 99热精品在线| 亚洲www美色| 国产伦精品一区三区视频| 成人免费观看视频| 亚洲 激情| 欧美大片aaaa一级毛片| 精品久久久久久中文字幕2017| 国产综合91天堂亚洲国产| 毛片高清| 久久99中文字幕| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 精品视频在线看| 午夜精品国产自在现线拍| 欧美激情伊人| 国产一区国产二区国产三区| 欧美大片a一级毛片视频| 日韩一级黄色大片| 成人免费网站视频ww| 高清一级毛片一本到免费观看| 欧美a级片免费看| 天天做日日爱夜夜爽| 欧美1区2区3区| 毛片电影网| 国产成人啪精品| 亚洲精品久久久中文字| 国产麻豆精品高清在线播放| 九九精品影院| 麻豆网站在线看| 高清一级淫片a级中文字幕| 91麻豆精品国产自产在线| 亚洲天堂在线播放| 精品国产香蕉伊思人在线又爽又黄| 欧美激情一区二区三区视频 | 久久99欧美| 久久精品道一区二区三区| 午夜在线亚洲| 黄视频网站免费| 久草免费在线观看| 成人a大片高清在线观看| 免费国产在线观看不卡| 一本高清在线| 国产麻豆精品视频| 亚洲精品久久玖玖玖玖| 韩国三级香港三级日本三级la| 久久国产精品永久免费网站| 黄视频网站免费观看| 免费国产在线视频| 精品视频在线看| 免费毛片基地| 韩国毛片免费| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 国产一区二区精品久久91| 欧美另类videosbestsex久久| 九九久久国产精品大片| 日韩专区第一页| 国产91精品系列在线观看| 一级毛片视频免费| 美女免费黄网站| 麻豆系列 在线视频| 尤物视频网站在线| 91麻豆精品国产片在线观看| 精品国产亚一区二区三区| 日韩专区亚洲综合久久| 91麻豆精品国产自产在线| 国产亚洲精品aaa大片| 一级片片| 91麻豆精品国产自产在线| 精品视频在线观看一区二区三区| 麻豆午夜视频| 国产美女在线观看| 国产网站免费观看| 九九免费精品视频| 香蕉视频三级| 国产视频久久久| 国产一区二区精品久久91| 韩国三级视频在线观看| 成人免费观看男女羞羞视频| 韩国三级视频网站| 国产成人女人在线视频观看| 精品在线观看一区| 91麻豆tv| 美女免费黄网站| 日韩免费在线| 二级片在线观看| 免费一级片在线| 日本在线www| 国产亚洲精品成人a在线| 四虎影视久久| 国产一区二区精品| a级精品九九九大片免费看| 精品视频在线观看一区二区| 国产视频久久久| 欧美日本二区| 精品视频一区二区三区免费| 欧美大片a一级毛片视频| 天天色色色| 九九精品久久| 韩国三级香港三级日本三级| 亚洲精品久久玖玖玖玖| 成人a大片在线观看| 国产精品免费久久| 欧美电影免费| 国产伦理精品| 日本免费看视频| 国产不卡在线观看视频| 国产精品123| 日本特黄特色aa大片免费| 人人干人人草| 久久久成人网| 欧美激情一区二区三区中文字幕| 欧美激情一区二区三区在线 | 午夜激情视频在线观看 | 韩国三级香港三级日本三级| 99色视频在线观看| 国产一区国产二区国产三区| 国产麻豆精品免费视频| 国产麻豆精品高清在线播放| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 日本在线不卡视频| 亚洲精品久久久中文字| 你懂的国产精品| 国产成人啪精品| 黄色免费三级| 欧美一区二区三区在线观看| 亚洲女人国产香蕉久久精品| 精品国产一区二区三区久久久狼| 国产一级生活片| 99色视频| 国产视频久久久| 亚洲天堂在线播放| 国产不卡福利| 国产精品免费精品自在线观看| 欧美激情一区二区三区在线| 91麻豆tv| 韩国三级视频网站| 亚洲第一色在线| 久草免费在线视频| 欧美国产日韩精品| 国产精品自拍亚洲| 韩国三级香港三级日本三级| 国产成人精品影视| 国产韩国精品一区二区三区| 亚洲爆爽| 香蕉视频久久| 99久久精品国产高清一区二区| 美女免费精品视频在线观看| 国产精品1024永久免费视频| 青青青草视频在线观看| 高清一级淫片a级中文字幕| 美国一区二区三区| 精品在线视频播放| 欧美大片毛片aaa免费看| 久久国产精品只做精品| 国产亚洲精品aaa大片| 欧美爱色| 国产成人精品影视| 天堂网中文字幕| 九九免费精品视频| 精品毛片视频| 国产一级生活片| 国产伦精品一区二区三区在线观看| 精品视频免费看| 欧美1区2区3区| 亚欧乱色一区二区三区| 久草免费在线观看| 成人高清视频在线观看| 精品国产一区二区三区久久久狼| 99久久精品国产麻豆| 欧美大片一区| 欧美大片aaaa一级毛片| 韩国毛片免费| 久久99中文字幕| 欧美激情一区二区三区视频高清| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 99久久精品国产麻豆| 日韩免费在线观看视频| 91麻豆爱豆果冻天美星空| 天天色色色| 亚洲精品中文一区不卡| 精品久久久久久中文字幕一区| 精品久久久久久中文字幕一区| 青草国产在线| 成人a级高清视频在线观看| 91麻豆精品国产高清在线| 天堂网中文字幕| 99热精品在线|