MySQL 如何在查询中获得一个值的总出现次数
为此,您可以使用子查询。首先让我们创建一个表 –
mysql> create table DemoTable
-> (
-> Value int
-> );
Query OK,0 rows affected (0.61 sec)
使用插入命令在表中插入一些记录 –
mysql> insert into DemoTable values(20);
Query OK,1 row affected (0.23 sec)
mysql> insert into DemoTable values(30);
Query OK,1 row affected (0.36 sec)
mysql> insert into DemoTable values(20);
Query OK,1 row affected (0.10 sec)
mysql> insert into DemoTable values(40);
Query OK,1 row affected (0.14 sec)
mysql> insert into DemoTable values(30);
Query OK,1 row affected (0.16 sec)
mysql> insert into DemoTable values(20);
Query OK,1 row affected (0.20 sec)
使用select语句显示表中的所有记录 –
mysql> select *from DemoTable;
阅读更多:MySQL 教程
输出
这将产生以下输出 –
+-------+
| Value |
+-------+
| 20 |
| 30 |
| 20 |
| 40 |
| 30 |
| 20 |
+-------+
6 rows in set (0.00 sec)
以下是获取值的总出现次数的查询 –
mysql> select tbl.Value,(SELECT COUNT(*) from DemoTable where Value = tbl.Value) AS Occurrence from DemoTable tbl;
输出
这将产生以下输出 –
+-------+------------+
| Value | Occurrence |
+-------+------------+
| 20 | 3 |
| 30 | 2 |
| 20 | 3 |
| 40 | 1 |
| 30 | 2 |
| 20 | 3 |
+-------+------------+
6 rows in set (0.00 sec)
极客教程