亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

mysql中g(shù)roup by與having合用注意事項(xiàng)分享

 更新時(shí)間:2013年10月09日 22:53:20   作者:  
在mysql中g(shù)roup by分組查詢(xún)我們經(jīng)常會(huì)用到,并且還同時(shí)會(huì)與having合用,下面我介紹group by用法與having合用注意事項(xiàng),希望此教程對(duì)各位朋友有所幫助

group by函數(shù)應(yīng)該的使用應(yīng)該是SELECT 列表中指定的每一列也必須出現(xiàn)在 GROUP BY 子句中,除非這列是用于聚合函數(shù),但是今天幫同事調(diào)試一個(gè)mysql中的group by函數(shù),讓我大跌眼鏡,當(dāng)時(shí)感覺(jué)不可思議,然后回來(lái)做了個(gè)簡(jiǎn)化版試驗(yàn),試驗(yàn)過(guò)程如下:

mysql表結(jié)構(gòu)

復(fù)制代碼 代碼如下:

mysql> desc t;
+——-+————–+——+—–+———+——-+
| Field | Type | Null | Key | Default | Extra |
+——-+————–+——+—–+———+——-+
| id | int(11) | YES | | 0 | |
| name | varchar(100) | YES | | NULL | |
| aa | varchar(45) | YES | | NULL | |
+——-+————–+——+—–+———+——-+
3 rows in set (0.01 sec)

插入數(shù)據(jù)

復(fù)制代碼 代碼如下:

mysql> select * from t;
+——+——+——-+
| id | name | aa |
+——+——+——-+
| 1 | aaaa | bbbb |
| 1 | 1111 | 2222 |
| 1 | 2222 | 33333 |
| 1 | 2222 | 44444 |
| 2 | 2222 | 44444 |
| 2 | 2222 | 1111 |
| 3 | 2222 | 1111 |
| 1 | 2222 | 44444 |
| 1 | 2222 | 44444 |
| 1 | 2222 | 44444 |
| 3 | 2222 | aaaa |
+——+——+——-+
11 rows in set (0.00 sec)

group by 查詢(xún)語(yǔ)句

復(fù)制代碼 代碼如下:

mysql> select id,count(1) ,aa from t group by id;
+——+———-+——-+
| id | count(1) | aa |
+——+———-+——-+
| 1 | 7 | bbbb |
| 2 | 2 | 44444 |
| 3 | 2 | 1111 |
+——+———-+——-+
3 rows in set (0.00 sec)

在本試驗(yàn)中,一共select id,count(1),aa,結(jié)果group by按照規(guī)則,除了聚合函數(shù)(count(1))外,其他兩列(id,aa)都應(yīng)該包含在group by中,可是試驗(yàn)只是包含了id。

對(duì)試驗(yàn)結(jié)果的說(shuō)明
1、包含在group by后面的id列的count(1)統(tǒng)計(jì)數(shù)據(jù)為正確的
2、按照正常思維,aa的數(shù)據(jù)不能展示出來(lái),可是mysql選擇了展示表中aa數(shù)據(jù)的第一條
3、上述2也是個(gè)人猜測(cè),暫時(shí)未查到官方相關(guān)說(shuō)明

mysql group by having 用法

group by就是按照不同的字段進(jìn)行分組,數(shù)值可以實(shí)現(xiàn)匯總

例如數(shù)據(jù)庫(kù)中有A表,包括學(xué)生,學(xué)科,成績(jī)?nèi)齻€(gè)字段
數(shù)據(jù)庫(kù)結(jié)構(gòu)為
學(xué)生 學(xué)科 成績(jī)
張三 語(yǔ)文 80
張三 數(shù)學(xué) 100
李四 語(yǔ)文 70
李四 數(shù)學(xué) 80
李四 英語(yǔ) 80

那么
select 學(xué)生,sum(成績(jī)) from A group by 學(xué)生;
得到如下結(jié)果

學(xué)生 成績(jī)
張三 180
李四 230

==============================================================

如果考慮having
語(yǔ)句寫(xiě)成:
select 學(xué)生,sum(成績(jī)) from A group by 學(xué)生 having 成績(jī)=80;
得到結(jié)果就是這樣的

學(xué)生 成績(jī)
張三 80
李四 160

用having比 JOIN ON 相對(duì)好理解一些,簡(jiǎn)單一些。

mysql中g(shù)roup by having 用法需要注意的事項(xiàng):

GROUP BY:

group by 有一個(gè)原則,就是 select 后面的所有列中,沒(méi)有使用聚合函數(shù)的列,必須出現(xiàn)在 group by后面。

比如:

復(fù)制代碼 代碼如下:

select name,sum(point) from table_name

這樣sql語(yǔ)句會(huì)報(bào)錯(cuò),必須寫(xiě)成:

復(fù)制代碼 代碼如下:

select name,sum(point) from table_name GROUP BY name

HAVING

把 HAVING 加入 SQL 的原因是,WHERE 無(wú)法應(yīng)用于合計(jì)函數(shù),而如果沒(méi)有 HAVING,就無(wú)法測(cè)試結(jié)果條件。

復(fù)制代碼 代碼如下:

select name,sum(point)
from table_name GROUP BY name
HAVING sum(point)>1000

having通常和group by聯(lián)合使用.

相關(guān)文章

  • MySQL中的常用工具實(shí)例匯總(推薦)

    MySQL中的常用工具實(shí)例匯總(推薦)

    MySQL數(shù)據(jù)庫(kù)以體積小、速度快、總體擁有成本低等優(yōu)點(diǎn),深受廣大中小企業(yè)的喜愛(ài),下面這篇文章主要給大家介紹了關(guān)于MySQL中常用工具的相關(guān)資料,需要的朋友們可以參考學(xué)習(xí),下面來(lái)一起看看吧。
    2017-09-09
  • MySQL不使用order by實(shí)現(xiàn)排名的三種思路總結(jié)

    MySQL不使用order by實(shí)現(xiàn)排名的三種思路總結(jié)

    ORDER BY語(yǔ)句用于根據(jù)指定的列對(duì)結(jié)果集進(jìn)行排序,在日常開(kāi)發(fā)中也經(jīng)常會(huì)用到,但下面這篇文章主要給大家介紹了關(guān)于MySQL不使用order by實(shí)現(xiàn)排名的三種思路,需要的朋友可以參考下
    2021-06-06
  • 安裝和使用percona-toolkit來(lái)輔助操作MySQL的基本教程

    安裝和使用percona-toolkit來(lái)輔助操作MySQL的基本教程

    這篇文章主要介紹了安裝和使用percona-toolkit來(lái)輔助操作MySQL的基本教程,這里舉了五個(gè)最常見(jiàn)的命令用法,需要的朋友可以參考下
    2015-11-11
  • MySQL學(xué)習(xí)第二天 安裝和配置mysql winx64

    MySQL學(xué)習(xí)第二天 安裝和配置mysql winx64

    MySQL學(xué)習(xí)第二天,主要為大家詳細(xì)介紹了在Windows 64位操作系統(tǒng)下安裝和配置MySQL的具體步驟,整理一份mysql winx64安裝配置方法教程,感興趣的小伙伴們可以參考一下
    2016-05-05
  • MySQL窗口函數(shù)實(shí)現(xiàn)榜單排名

    MySQL窗口函數(shù)實(shí)現(xiàn)榜單排名

    相信大家在日常的開(kāi)發(fā)中經(jīng)常會(huì)碰到榜單類(lèi)的活動(dòng)需求,本文主要介紹了MySQL窗口函數(shù)實(shí)現(xiàn)榜單排名,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-04-04
  • 關(guān)于mysql中string和number的轉(zhuǎn)換問(wèn)題

    關(guān)于mysql中string和number的轉(zhuǎn)換問(wèn)題

    這篇文章主要介紹了關(guān)于mysql中string和number的轉(zhuǎn)換問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • 關(guān)于MySQL索引的幾點(diǎn)值得注意的事項(xiàng)

    關(guān)于MySQL索引的幾點(diǎn)值得注意的事項(xiàng)

    索引對(duì)查詢(xún)的速度有著至關(guān)重要的影響,MySQL索引的建立對(duì)于MySQL的高效運(yùn)行是很重要的
    2014-07-07
  • mysql 5.7.5 m15 winx64.zip安裝教程

    mysql 5.7.5 m15 winx64.zip安裝教程

    這篇文章主要為大家詳細(xì)介紹了mysql 5.7.5 m15 winx64.zip安裝教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • MYSQL 批量替換之replace語(yǔ)法的使用詳解

    MYSQL 批量替換之replace語(yǔ)法的使用詳解

    本篇文章是對(duì)MYSQL中replace語(yǔ)法的使用進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-07-07
  • MySQL創(chuàng)建用戶與授權(quán)方法

    MySQL創(chuàng)建用戶與授權(quán)方法

    MySQL中創(chuàng)建用戶與授權(quán)的實(shí)現(xiàn)方法,對(duì)于剛開(kāi)始接觸mysql的朋友可以參考下
    2012-11-11

最新評(píng)論