如何在單個 MySQL 查詢中合併查詢,以獲取不同列中不同值的計數?


我們首先建立一個表 -

mysql> create table DemoTable760 (
   ClientId int,
   ClientId2 int
);
Query OK, 0 rows affected (0.79 sec)

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

mysql> insert into DemoTable760 values(100,200);
Query OK, 1 row affected (0.17 sec)
mysql> insert into DemoTable760 values(100,200);
Query OK, 1 row affected (0.11 sec)
mysql> insert into DemoTable760 values(300,400);
Query OK, 1 row affected (0.13 sec)
mysql> insert into DemoTable760 values(300,400);
Query OK, 1 row affected (0.26 sec)
mysql> insert into DemoTable760 values(100,200);
Query OK, 1 row affected (0.23 sec)
mysql> insert into DemoTable760 values(100,200);
Query OK, 1 row affected (0.11 sec)
mysql> insert into DemoTable760 values(400,500);
Query OK, 1 row affected (0.08 sec)

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

mysql> select *from DemoTable760;

這將產生以下輸出 -

+----------+-----------+
| ClientId | ClientId2 |
+----------+-----------+
|      100 |       200 |
|      100 |       200 |
|      300 |       400 |
|      300 |       400 |
|      100 |       200 |
|      100 |       200 |
|      400 |       500 |
+----------+-----------+
7 rows in set (0.00 sec)

以下查詢用於將查詢合併到單個查詢中,以獲取不同列中不同值的計數 -

mysql> select sum(ClientId=100) AS ClientId1,sum(ClientId2=200) AS ClientId2 from DemoTable760;

這將產生以下輸出 -

+-----------+-----------+
| ClientId1 | ClientId2 |
+-----------+-----------+
|         4 |         4 |
+-----------+-----------+
1 row in set (0.00 sec)

更新於: 2019 年 9 月 3 日

170 次瀏覽

開啟你的 職業

完成該課程獲得認證

開始
廣告
© . All rights reserved.