欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

淺談MySQL中的group by

 更新時間:2021年11月20日 14:42:28   作者:李子捌  
這篇文章主要介紹了MySQL中的group by,MySQL的group by用于對查詢的數(shù)據(jù)進行分組;此外MySQL提供having子句對分組內(nèi)的數(shù)據(jù)進行過濾。下面來看看文章對此的具體介紹,需要的朋友可以參考一下,希望對你有所幫助

1、前言

MySQLgroup by用于對查詢的數(shù)據(jù)進行分組;此外MySQL提供having子句對分組內(nèi)的數(shù)據(jù)進行過濾。

MySQL提供了許多select子句關鍵字,

它們在語句中的順序如下所示:

子句 作用 是否必須/何時使用
select 查詢要返回的數(shù)據(jù)或者表達式
from 指定查詢的表
where 指定行級過濾
group by 分組 否/對數(shù)據(jù)分組時使用
having 分組過濾 否/對分組后的數(shù)據(jù)過濾使用
order by 返回數(shù)據(jù)時指定排序規(guī)則
limit 指定返回數(shù)據(jù)的行數(shù)

2、準備user表

準備一張user表,其DDL和表數(shù)據(jù)如下所示

SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;

-- ----------------------------
-- Table structure for user
-- ----------------------------
DROP TABLE IF EXISTS `user`;
CREATE TABLE `user`  (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主鍵',
  `name` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT '用戶名',
  `nation` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '民族',
  `age` int(11) NULL DEFAULT NULL COMMENT '年齡',
  `height` double NULL DEFAULT NULL COMMENT '身高',
  `sex` smallint(6) NULL DEFAULT NULL COMMENT '性別',
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;

-- ----------------------------
-- Records of user
-- ----------------------------
INSERT INTO `user` VALUES (1, '李子捌', '漢族', 18, 180, 1);
INSERT INTO `user` VALUES (2, '張三', '回族', 20, 175, 1);
INSERT INTO `user` VALUES (3, '李四', '維吾爾族', 45, 168, 0);
INSERT INTO `user` VALUES (4, '王五', '蒙古族', 18, 177, 1);
INSERT INTO `user` VALUES (5, '趙六', '漢族', 16, 184, 0);
INSERT INTO `user` VALUES (6, '田七', '維吾爾族', 27, 192, 1);

user表中數(shù)據(jù)如下所示:

mysql> select * from user;
+----+--------+----------+------+--------+------+
| id | name   | nation   | age  | height | sex  |
+----+--------+----------+------+--------+------+
|  1 | 李子捌 | 漢族     |   18 |    180 |    1 |
|  2 | 張三   | 回族     |   20 |    175 |    1 |
|  3 | 李四   | 維吾爾族 |   45 |    168 |    0 |
|  4 | 王五   | 蒙古族   |   18 |    177 |    1 |
|  5 | 趙六   | 漢族     |   16 |    184 |    0 |
|  6 | 田七   | 維吾爾族 |   27 |    192 |    1 |
+----+--------+----------+------+--------+------+
6 rows in set (0.00 sec)

2.1 group by規(guī)則

使用group by之前需要先了解group by使用的相關規(guī)則

  • group by子句置于where之后,order by子句之前
  • having 子句置于group by 之后,order by子句之前
  • group by子句中的每個列都必須是select的檢索列或者有效表達式,不能使用聚集函數(shù)
  • select中使用的表達式,在group by子句中必須出現(xiàn),并且不能使用別名
  • group by分組的數(shù)據(jù)中包含null值,null值被分為一組
  • group by子句可以嵌套,嵌套的分組在最后分組上匯總

2.2 group by使用

需求:

統(tǒng)計不同民族的用戶數(shù)

語句:

mysql> select nation, count(*) from user group by nation;
+----------+----------+
| nation   | count(*) |
+----------+----------+
| 漢族     |        2 |
| 回族     |        1 |
| 維吾爾族 |        2 |
| 蒙古族   |        1 |
+----------+----------+
4 rows in set (0.00 sec)

group by可以結合where一起使用,不過where不能在group by之后進行過濾,使用where子句之后,分組的數(shù)據(jù)是where子句過濾后的數(shù)據(jù)集。

mysql> select nation, count(*) as nation_num  from user where sex = 0 group by nation;
+----------+------------+
| nation   | nation_num |
+----------+------------+
| 維吾爾族 |          1 |
| 漢族     |          1 |
+----------+------------+
2 rows in set (0.00 sec)

2.3 having使用

group by分組后的數(shù)據(jù)還需要再次過濾,就必須使用having子句。group by子句后使用where子句MySQL服務器會拋出異常

mysql> select nation, count(*) as nation_num  from user group by nation where nation = '漢族';
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'where nation = '漢族'' at line 1


此時只需要將上面where子句替換成having子句即可,having子句支持所有的where操作符,通俗的說where子句能用的地方只有替換成having就可以在group by子句后使用了

vmysql> select nation, count(*) as nation_num  from user group by nation having nation = '漢族';
+--------+------------+
| nation | nation_num |
+--------+------------+
| 漢族   |          2 |
+--------+------------+
1 row in set (0.00 sec)

2.4 order by與limit

分組后的數(shù)據(jù)需要排序可以使用order by,order by子句需要更在having子句之后。

mysql> select nation, count(*) as nation_num  from user group by nation having nation != '漢族' order by nation_num desc;
+----------+------------+
| nation   | nation_num |
+----------+------------+
| 維吾爾族 |          2 |
| 回族     |          1 |
| 蒙古族   |          1 |
+----------+------------+
3 rows in set (0.00 sec)

對于輸出的結果需要指定返回的行數(shù),可以使用limit,limit子句在整個語句的最后。

mysql> select nation, count(*) as nation_num  from user group by nation having nation != '漢族' order by nation_num desc limit 2;
+----------+------------+
| nation   | nation_num |
+----------+------------+
| 維吾爾族 |          2 |
| 回族     |          1 |
+----------+------------+
2 rows in set (0.00 sec)

2.5 with rollup

在group by子句中,WITH ROLLUP 可以實現(xiàn)在分組統(tǒng)計數(shù)據(jù)基礎上再進行相同的統(tǒng)計(SUM,AVG,COUNT…)

比如max():

mysql> select nation, max(height) as nation_num  from user group by nation with rollup;
+----------+------------+
| nation   | nation_num |
+----------+------------+
| 回族     |        175 |
| 漢族     |        184 |
| 維吾爾族 |        192 |
| 蒙古族   |        177 |
| NULL     |        192 |
+----------+------------+
5 rows in set (0.00 sec)

比如avg():

mysql> select nation, avg(height) as nation_num  from user group by nation with rollup;
+----------+--------------------+
| nation   | nation_num         |
+----------+--------------------+
| 回族     |                175 |
| 漢族     |                182 |
| 維吾爾族 |                180 |
| 蒙古族   |                177 |
| NULL     | 179.33333333333334 |
+----------+--------------------+
5 rows in set (0.00 sec)

比如count():

mysql> select nation, count(*) as nation_num  from user group by nation with rollup;
+----------+------------+
| nation   | nation_num |
+----------+------------+
| 回族     |          1 |
| 漢族     |          2 |
| 維吾爾族 |          2 |
| 蒙古族   |          1 |
| NULL     |          6 |
+----------+------------+
5 rows in set (0.00 sec)

到此這篇關于淺談MySQL中的group by的文章就介紹到這了,更多相關MySQL中的group by內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • mysql性能監(jiān)控工具Innotop簡介及配置

    mysql性能監(jiān)控工具Innotop簡介及配置

    INNOTOP是一個通過文本模式顯示MySQL和InnoDB的監(jiān)測工具。INNOTOP是用PERL語言寫成的,這使它能更加靈活的使用在各種操作平臺之上,它能詳細的的監(jiān)控出當前MYSQL和INNODB運行的狀態(tài),以DBA根據(jù)結果,可以合理的優(yōu)化MYSQL,讓MYSQL更穩(wěn)定更高效的運行。
    2014-08-08
  • SQL Server 2005 安裝遇到的錯誤提示和解決方法

    SQL Server 2005 安裝遇到的錯誤提示和解決方法

    在安裝SQL Server 2005時有時會出現(xiàn)意想不到的問題,如IIS,性能計數(shù)器,OWC11,無法配置外圍應用的問題,下面筆者分享一下在安裝SQL Server 2005時常見問題解決方法
    2014-01-01
  • Win7 安裝 Mysql 5.6的教程圖解

    Win7 安裝 Mysql 5.6的教程圖解

    這篇文章主要介紹了Win7 安裝 Mysql 5.6的教程,本文圖文并茂給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-09-09
  • MySQL的LEFT JOIN表連接的進階學習教程

    MySQL的LEFT JOIN表連接的進階學習教程

    這篇文章主要介紹了MySQL的LEFT JOIN表連接的進階學習教程,包括對左連接的查詢效率分析以及相關建議,需要的朋友可以參考下
    2015-12-12
  • Centos7安裝和配置Mysql5.7

    Centos7安裝和配置Mysql5.7

    網(wǎng)上關于Linux安裝mysql數(shù)據(jù)庫的教程數(shù)不勝數(shù),但是,大多教程都是漏洞百出。今天,為了幫助各位需要的人,從而寫下Centos7安裝配置mysql5.7的教程。
    2018-02-02
  • MySQL5.6主從復制(mysql數(shù)據(jù)同步配置)

    MySQL5.6主從復制(mysql數(shù)據(jù)同步配置)

    這篇文章主要介紹了MySQL5.6主從復制也就是mysql數(shù)據(jù)同步配置方法,需要的朋友可以參考下
    2016-11-11
  • Mysql實現(xiàn)全文檢索、關鍵詞跑分的方法實例

    Mysql實現(xiàn)全文檢索、關鍵詞跑分的方法實例

    這篇文章主要給大家介紹了關于Mysql實現(xiàn)全文檢索、關鍵詞跑分的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-09-09
  • mysql Innodb表空間卸載、遷移、裝載的使用方法

    mysql Innodb表空間卸載、遷移、裝載的使用方法

    從MySQL的Innodb特性中我們知道,Inndob的表空間有共享和獨享的特點,如果是共享的。則默認會把表空間存放在一個文件中(ibdata1),當開啟獨享表空間參數(shù)Innodb_file_per_table時,會為每個Innodb表創(chuàng)建一個.ibd的文件。文章討論在獨享表空間卸載、裝載、遷移Innodb表的情況
    2013-11-11
  • MySQL導出所有Index和約束的方法

    MySQL導出所有Index和約束的方法

    這篇文章主要介紹了MySQL導出所有Index和約束的方法,非常實用的技巧,需要的朋友可以參考下
    2014-08-08
  • mysql數(shù)據(jù)庫單表最大存儲依據(jù)詳解

    mysql數(shù)據(jù)庫單表最大存儲依據(jù)詳解

    這篇文章主要為大家介紹了mysql數(shù)據(jù)庫單表最大存儲的依據(jù)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07

最新評論