亚洲综合无码久久精品综合_宅男app软件_亚洲av中文无码乱人伦在线r_蜜臀91丨九色丨蝌蚪老版_老女人与小男人一级毛片

集團官網(wǎng)
  • 國家級全民數(shù)字素養(yǎng)與技能培訓基地
  • 河南省第一批產(chǎn)教融合型企業(yè)建設(shè)培育單位
  • 鄭州市數(shù)字技能人才(碼農(nóng))培養(yǎng)評價聯(lián)盟

新手起步理解group by

編輯:云和數(shù)據(jù) 日期:2023-11-18 09:48

dfe4b86db3f8af9549cbb26b76f971f.png

MySQL 中,GROUP?BY用于將具有指定列中相同值的行分組在一起,允許對數(shù)據(jù)進行分類和聚合,即按照指定的字段或者表達式進行分組。

我們現(xiàn)在有一個簡單的表student,內(nèi)容如下表1所示:

1d8d51a58c3331c1b8e411851afde2c.png

對于上面這個表,我們要求查詢每個班幾個人?

答案是:select class,count(class) from student group by class;

有很多初學者在學習group by時,不明白為什么不是select * from student ?group by ?class,為什么一定不能是*,而是某一個列或者某個列的聚合函數(shù),group by 應(yīng)該怎么去理解呢?

上表如果執(zhí)行 select name from class;語句,應(yīng)該很好理解,展示如下表2內(nèi)容:

421c66e9a136c4627dcc5274a775b2e.png

為了能夠更好的理解“group by”多個列“和”聚合函數(shù)“的應(yīng)用,我們在思考的過程中,由表1到表2的過程中,增加一個虛構(gòu)的中間表:虛擬表3。下面說說如何思考上面SQL語句執(zhí)行情況:

1.from ?student:該句執(zhí)行后,應(yīng)該結(jié)果和表1一樣,就是原來的student表。

2.from ?student ?group ?by ??class:該句執(zhí)行后,生成過程是這樣的:group ?by ?class,那么找class那一列,具有相同class值的行,合并成一行,我們想象生成了虛擬表3,如下所圖所示。如對于class值為”一班” 的,那么id為1,3,4的三行合并成1行,即所有的id值,name值和class值寫到一行里面,同樣,對于class值為”二班”的,那么id為2,3的二行合并成一行,所有的id值,name值和class值寫到一行里面。

bd2d796b3675633dbd29bfc02dd08fb.png

3.接下來就要針對虛擬表3執(zhí)行Select語句了:

1)如果執(zhí)行select *的話,那么返回的結(jié)果應(yīng)該是虛擬表3,可是id和name中有的單元格里面的內(nèi)容是多個值,而關(guān)系數(shù)據(jù)庫就是基于關(guān)系的,一個單元格中是不允許有多個值的,所以執(zhí)行select * 語句就報錯了。

2)我們再看class列,每個單元格只有一個數(shù)據(jù),所以我們select class的話,就沒有問題了。為什么class列每個單元格只有一個值呢?因為我們就是用class列來group by的。

3)那么對于id和name里面的單元格有多個數(shù)據(jù)的情況怎么辦呢?答案就是使用聚合函數(shù),聚合函數(shù)就用來輸入多個數(shù)據(jù),輸出一個數(shù)據(jù)的。如count(class)等聚合函數(shù),而每個聚合函數(shù)的輸入就是每一個多數(shù)據(jù)的單元格。

4、所以,我們執(zhí)行select ?class, count(class) ?from ?student ?group ?by ?class;,那么count(class)就對虛擬表3的class列的每個單元格進行count操作,最后執(zhí)行結(jié)果如下:

9e7c76cea940ee34798186b871c0315.png

所以,通過上面的分析,如果對多個字段進行分組,原理也是一樣的。

相關(guān)內(nèi)容

搶先一步 鴻蒙(HarmonyOS)應(yīng)用開發(fā)者高級認證 免費考! 適合人群計算機相關(guān)專業(yè)在校生(技師、中職、高職、本科、研究生)對鴻蒙(HarmonyOS)有興趣的非計算機相關(guān)專業(yè)在校生目前正在從事移動應(yīng)用的開發(fā)者目前正在從事計算機行業(yè)相關(guān)的人計算機專業(yè)高校老師所有對鴻蒙(HarmonyOS)有興趣的人 培訓方案掌握鴻蒙的核心概念和端云一體化開發(fā)、... 什么是Java的多態(tài)性(polymorphism)?它有哪些不同的形式? 多態(tài)性是Java面向?qū)ο缶幊痰囊粋€重要概念,它允許不同的對象以一致的方式響應(yīng)同一個方法調(diào)用,具體表現(xiàn)為對象在運行時可以表現(xiàn)出多個不同的形態(tài)。多態(tài)性主要有兩種不同的形式:編譯時多態(tài)性(靜態(tài)多態(tài)性)和運行時多態(tài)性(動態(tài)多態(tài)性)。1. 編譯時多態(tài)性(靜態(tài)多態(tài)性):   ... 如何學習和搭建Hadoop開發(fā)環(huán)境? Hadoop是大數(shù)據(jù)處理領(lǐng)域的重要平臺,能夠處理和分析大量數(shù)據(jù)。為了有效地利用Hadoop,我們需要學習其基礎(chǔ)知識,并正確搭建開發(fā)環(huán)境。下面是詳細的學習和搭建指南。一、學習Hadoop基礎(chǔ)掌握基礎(chǔ)概念和原理Hadoop主要由HDFS和MapReduce兩部分組成。HDFS是分布式文件系統(tǒng),Ma... UI 設(shè)計學習如何進階成為高手 我總結(jié)了六種方法,幫助你走出舒適區(qū),提高技能,成長為自信且經(jīng)驗豐富的UI設(shè)計高手一位經(jīng)驗豐富的 UI 設(shè)計師,往往十分看中應(yīng)用程序界面的吸引力和視覺刺激,確保滿足用戶期望和需求。但是,如果你已經(jīng)在 UI 設(shè)計圈摸爬滾打多年,仍然沒有出色的作品,那你極有可能是因為陷入了一個舒適圈,UI技能一直原... 在Java中Executor和Executors的區(qū)別? 在Java中,Executor和Executors都與線程池和并發(fā)執(zhí)行有關(guān),但它們是不同的概念和類。1.ExecutorExecutor是一個接口,位于java.util.concurrent包中,用于表示一個執(zhí)行任務(wù)的執(zhí)行器。它只定義了一個方法:void execute(Runnable c... String類型的常見命令有哪些? String類型,也就是字符串類型,是Redis中最簡單的存儲類型。其value是字符串,不過根據(jù)字符串的格式不同,又可以分為3類:string是普通字符串,int整數(shù)類型,可以做自增、自減操作,float浮點類型,可以做自增、自減操作。String的常見命令有:SET:添加或者修改已經(jīng)存在的...