久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

    1. <style id="76ofp"></style>

      <style id="76ofp"></style>
      <rt id="76ofp"></rt>
      <form id="76ofp"><optgroup id="76ofp"></optgroup></form>
      1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

        手機(jī)站
        千鋒教育

        千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

        千鋒教育

        掃一掃進(jìn)入千鋒手機(jī)站

        領(lǐng)取全套視頻
        千鋒教育

        關(guān)注千鋒學(xué)習(xí)站小程序
        隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

        當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > 如果有子查詢SQL語(yǔ)句的執(zhí)行順序是怎么樣的?

        如果有子查詢SQL語(yǔ)句的執(zhí)行順序是怎么樣的?

        來(lái)源:千鋒教育
        發(fā)布人:xqq
        時(shí)間: 2023-10-13 19:06:26 1697195186

        一、如果有子查詢SQL語(yǔ)句的執(zhí)行順序是怎么樣的

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

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

        例如:

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

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

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

        子查詢作為HAVING子句的一部分時(shí),首先會(huì)對(duì)GROUP BY子句所指定的列進(jìn)行分組,然后再執(zhí)行子查詢,得到結(jié)果集后,將該結(jié)果集作為條件與分組后的每個(gè)組進(jìn)行比較,只有符合條件的組才會(huì)被返回。

        例如:

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

        此處,首先會(huì)對(duì)table_name中的列進(jìn)行分組,然后在每個(gè)組內(nèi)部執(zhí)行子查詢,得到結(jié)果集,并返回那些最大值大于another_table_name中的列值的組。

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

        子查詢作為SELECT子句的一部分時(shí),首先會(huì)執(zhí)行子查詢,得到結(jié)果集后,將該結(jié)果集作為列值加入到外層查詢的結(jié)果集中。

        例如:

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

        此處,子查詢會(huì)首先執(zhí)行,得到結(jié)果集,并將其作為一列(column_name3)加入到當(dāng)前查詢結(jié)果集中。

        二、SQL單表查詢

        1、簡(jiǎn)介

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

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

        其中:

        SELECT 子句用于指定輸出的字段FROM 子句用于指定數(shù)據(jù)的來(lái)源WHERE 子句用于指定數(shù)據(jù)的行選擇條件GROUP BY 子句用于對(duì)檢索到的記錄進(jìn)行分組HAVING 子句用于指定對(duì)分組后結(jié)果的選擇條件ORDER BY 子句用于對(duì)查詢的結(jié)果進(jìn)行排序

        2、選擇表中若干列

        查詢指定的列:

        -- 查詢?nèi)w學(xué)生的學(xué)好與姓名
        SELECT Sno, Sname FROM Student

        查詢?nèi)苛校?/p>

        -- 查詢?nèi)w學(xué)生的全部信息
        SELECT Sno, Sname, Ssex, Sbirthday, Sdept, Memo FROM Student
        -- 等價(jià)于
        SELECT * FROM Student

        查詢表中沒(méi)有的列:

        -- 含表達(dá)式的列:查詢?nèi)w學(xué)生的姓名及年齡(年齡的列名是空)SELECT Sname, YEAR(GETDATE()) - YEAR(Sbirthday) FROM Student-- 查詢?nèi)w學(xué)生的姓名、年齡、字符串“今年是”以及今年的年份(給列取別名)SELECT Sname 姓名,YEAR(GETDATE()) - YEAR(Sbirthday) 年齡,'今年是' 今年是, YEAR(GETDATE()) 年份FROM Student

        3、選擇表中若干行

        查詢滿足條件的元組:

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

        消除取值相同的行:

        /*雖然原關(guān)系中不存在兩個(gè)完全相同的元組,但經(jīng)過(guò)一定操作后可能會(huì)出現(xiàn)相同的元組*/-- 查詢有考試掛科的學(xué)生的學(xué)號(hào)SELECT DISTINCT Sno FROM SCWHERE Grade < 60

        延伸閱讀1:SQL語(yǔ)法要求

        SQL語(yǔ)句可以單行或多行書寫,以分號(hào)結(jié)尾;可以用空格和縮進(jìn)來(lái)來(lái)增強(qiáng)語(yǔ)句的可讀性;關(guān)鍵字不區(qū)別大小寫,建議使用大寫。
        聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
        10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
        請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
        免費(fèi)領(lǐng)取
        今日已有369人領(lǐng)取成功
        劉同學(xué) 138****2860 剛剛成功領(lǐng)取
        王同學(xué) 131****2015 剛剛成功領(lǐng)取
        張同學(xué) 133****4652 剛剛成功領(lǐng)取
        李同學(xué) 135****8607 剛剛成功領(lǐng)取
        楊同學(xué) 132****5667 剛剛成功領(lǐng)取
        岳同學(xué) 134****6652 剛剛成功領(lǐng)取
        梁同學(xué) 157****2950 剛剛成功領(lǐng)取
        劉同學(xué) 189****1015 剛剛成功領(lǐng)取
        張同學(xué) 155****4678 剛剛成功領(lǐng)取
        鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
        董同學(xué) 138****2867 剛剛成功領(lǐng)取
        周同學(xué) 136****3602 剛剛成功領(lǐng)取
        相關(guān)推薦HOT
        用count(*)做判斷條件怎么弄的好一點(diǎn)?

        一、用count(*)做判斷條件弄的好一點(diǎn)的方法1、使用索引來(lái)優(yōu)化查詢?nèi)绻樵冎猩婕暗降谋淼牧卸家烟砑恿苏_的索引,那么查詢的效率將得到大幅...詳情>>

        2023-10-13 20:14:55
        teradata與greenplum的區(qū)別?

        一、teradata與greenplum的區(qū)別 1、架構(gòu)不同:Teradata是一種對(duì)稱多處理(Symmetric Multiprocessing,SMP)架構(gòu),而Greenplum是一種以共享無(wú)阻塞詳情>>

        2023-10-13 20:07:18
        arcgis的mdb數(shù)據(jù)庫(kù)怎么轉(zhuǎn)成db數(shù)據(jù)庫(kù)?

        一、arcgis的mdb數(shù)據(jù)庫(kù)轉(zhuǎn)成db數(shù)據(jù)庫(kù)的方法1、導(dǎo)出mdb數(shù)據(jù)庫(kù)中的數(shù)據(jù)表使用ArcGIS中的Export功能將MDB數(shù)據(jù)庫(kù)中的數(shù)據(jù)表導(dǎo)出為CSV或Excel格式的文...詳情>>

        2023-10-13 20:04:31
        怎么分析判斷一個(gè)網(wǎng)站的后臺(tái)數(shù)據(jù)庫(kù)管理系統(tǒng)是什么?

        一、分析判斷一個(gè)網(wǎng)站的后臺(tái)數(shù)據(jù)庫(kù)管理系統(tǒng)是什么的方法1、根據(jù)網(wǎng)頁(yè)編程語(yǔ)言去判斷結(jié)合網(wǎng)頁(yè)編程語(yǔ)言和后臺(tái)數(shù)據(jù)庫(kù)系統(tǒng)的常見搭配可以判斷出該網(wǎng)...詳情>>

        2023-10-13 20:00:20
        MYSQL的幻讀和我們平常說(shuō)的幻讀有什么區(qū)別?

        一、MYSQL的幻讀和我們平常說(shuō)的幻讀有什么區(qū)別平常說(shuō)的幻讀:事務(wù)1查詢id詳情>>

        2023-10-13 19:58:38
        快速通道
        洪湖市| 手游| 宜良县| 漾濞| 武义县| 扬中市| 定襄县| 福安市| 闻喜县| 兴安县| 巨鹿县| 武清区| 东兴市| 吉木萨尔县| 广安市| 延庆县| 大同市| 深圳市| 获嘉县| 塔河县| 卢湾区| 深州市| 盐亭县| 海南省| 亳州市| 贞丰县| 华安县| 平定县| 昆明市| 巴里| 肇源县| 高要市| 贵州省| 柯坪县| 宁国市| 汉源县| 兰坪| 原平市| 策勒县| 白玉县| 西盟|