小編給大家分享一下MySQL中g(shù)roup by如何使用,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!
成都創(chuàng)新互聯(lián)公司-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比鋼城網(wǎng)站開(kāi)發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式鋼城網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋鋼城地區(qū)。費(fèi)用合理售后完善,10余年實(shí)體公司更值得信賴。
mysql中g(shù)roup by的用法是配合聚合函數(shù),利用分組信息進(jìn)行統(tǒng)計(jì),語(yǔ)句如“select name,sum(id) from test group by name,number”。
先來(lái)看下表1,表名為test:
執(zhí)行如下SQL語(yǔ)句:
SELECT name FROM test GROUP BY name
你應(yīng)該很容易知道運(yùn)行的結(jié)果,沒(méi)錯(cuò),就是下表2:
可是為了能夠更好的理解“group by”多個(gè)列“和”聚合函數(shù)“的應(yīng)用,我建議在思考的過(guò)程中,由表1到表2的過(guò)程中,增加一個(gè)虛構(gòu)的中間表:虛擬表3。下面說(shuō)說(shuō)如何來(lái)思考上面SQL語(yǔ)句執(zhí)行情況:
1.FROM test:該句執(zhí)行后,應(yīng)該結(jié)果和表1一樣,就是原來(lái)的表。
2.FROM test Group BY name:該句執(zhí)行后,我們想象生成了虛擬表3,如下所圖所示,生成過(guò)程是這樣的:group by name,那么找name那一列,具有相同name值的行,合并成一行,如對(duì)于name值為aa的,那么<1 aa 2>與<2 aa 3>兩行合并成1行,所有的id值和number值寫到一個(gè)單元格里面,如下圖所示
3.接下來(lái)就要針對(duì)虛擬表3執(zhí)行Select語(yǔ)句了:
(1)如果執(zhí)行select *的話,那么返回的結(jié)果應(yīng)該是虛擬表3,可是id和number中有的單元格里面的內(nèi)容是多個(gè)值的,那么id跟number會(huì)返回各自單元格中的排序第一個(gè)值。id列會(huì)返回1,3,5
(2)我們?cè)倏磏ame列,每個(gè)單元格只有一個(gè)數(shù)據(jù),所以我們select name的話,就沒(méi)有問(wèn)題了。為什么name列每個(gè)單元格只有一個(gè)值呢,因?yàn)槲覀兙褪怯胣ame列來(lái)group by的。
(3)那么對(duì)于id和number里面的單元格有多個(gè)數(shù)據(jù)的情況怎么辦呢?答案就是用聚合函數(shù),聚合函數(shù)就用來(lái)輸入多個(gè)數(shù)據(jù),輸出一個(gè)數(shù)據(jù)的。如count(id),sum(number),而每個(gè)聚合函數(shù)的輸入就是每一個(gè)多數(shù)據(jù)的單元格。
(4)例如我們執(zhí)行select name,sum(number) from test group by name,那么sum就對(duì)虛擬表3的number列的每個(gè)單元格進(jìn)行sum操作,例如對(duì)name為aa的那一行的number列執(zhí)行sum操作,即2+3,返回5,最后執(zhí)行結(jié)果如下:
5)group by 多個(gè)字段該怎么理解呢:如group by name,number,我們可以把name和number 看成一個(gè)整體字段,以他們整體來(lái)進(jìn)行分組,如下圖所示:
6)接下來(lái)就可以配合select和聚合函數(shù)進(jìn)行操作了。如執(zhí)行select name,sum(id) from test group by name,number,結(jié)果如下圖:
看完了這篇文章,相信你對(duì)mysql中g(shù)roup by如何使用有了一定的了解,想了解更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!