用於按列分組並顯示另一列中相似值的總和的 MySQL 查詢


為此,請使用 GROUP BY HAVING 子句。

我們首先建立一個表 -

mysql> create table DemoTable782 (
   Name varchar(100),
   Score int
);
Query OK, 0 rows affected (1.18 sec)

使用 insert 命令向表中插入一些記錄 -

mysql> insert into DemoTable782 values('John',156);
Query OK, 1 row affected (0.18 sec)
mysql> insert into DemoTable782 values('Carol',250);
Query OK, 1 row affected (0.15 sec)
mysql> insert into DemoTable782 values('Bob',140);
Query OK, 1 row affected (0.17 sec)
mysql> insert into DemoTable782 values('John',126);
Query OK, 1 row affected (0.29 sec)
mysql> insert into DemoTable782 values('John',140);
Query OK, 1 row affected (0.17 sec)
mysql> insert into DemoTable782 values('Bob',280);
Query OK, 1 row affected (0.17 sec)
mysql> insert into DemoTable782 values('Bob',250);
Query OK, 1 row affected (0.41 sec)
mysql> insert into DemoTable782 values('Carol',189);
Query OK, 1 row affected (0.17 sec)
mysql> insert into DemoTable782 values('Carol',299);
Query OK, 1 row affected (0.21 sec)

使用 select 語句顯示錶中的所有記錄 -

mysql> select *from DemoTable782;

這將產生以下輸出 -

+-------+-------+
| Name  | Score |
+-------+-------+
| John  | 156   |
| Carol | 250   |
| Bob   | 140   |
| John  | 126   |
| John  | 140   |
| Bob   | 280   |
| Bob   | 250   |
| Carol | 189   |
| Carol | 299   |
+-------+-------+
9 rows in set (0.00 sec)

以下是按列分組並顯示相似值總和的查詢 -

mysql> select Name,SUM(Score) AS Total
   from DemoTable782
   group by Name
   HAVING Total > 500;

這將產生以下輸出 -

+-------+-------+
| Name  | Total |
+-------+-------+
| Carol | 738   |
| Bob   | 670   |
+-------+-------+
2 rows in set (0.00 sec)

更新時間:2019 年 9 月 9 日

462 次瀏覽

開啟你的 職業生涯

完成課程並取得認證

開始
廣告
© . All rights reserved.