如何統計從 MySQL 資料庫中檢索的行中逗號分隔的特定值?


要統計逗號分隔的值,請將聚合函式 COUNT(*) 與 FIND_IN_SET() 一起使用。我們先建立一個表 -

mysql> create table DemoTable
(
   Value varchar(100)
);
Query OK, 0 rows affected (0.49 sec)

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

mysql> insert into DemoTable values('10,20,60,80');
Query OK, 1 row affected (0.12 sec)
mysql> insert into DemoTable values('60,70,90');
Query OK, 1 row affected (0.12 sec)
mysql> insert into DemoTable values('50,55,65,60');
Query OK, 1 row affected (0.12 sec)
mysql> insert into DemoTable values('90,98,97');
Query OK, 1 row affected (0.12 sec)

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

mysql> select *from DemoTable;

這將產生以下輸出 -

+-------------+
| Value       |
+-------------+
| 10,20,60,80 |
| 60,70,90    |
| 50,55,65,60 |
| 90,98,97    |
+-------------+
4 rows in set (0.00 sec)

以下是從資料庫中檢索逗號分隔值的查詢 -

mysql> select count(*) from DemoTable
   where find_in_set('60',Value) > 0;

這將產生以下輸出 -

+----------+
| count(*) |
+----------+
|        3 |
+----------+
1 row in set (0.00 sec)

更新於:04-Oct-2019

413 次瀏覽

開啟你的職業生涯

完成課程獲得認證

開始吧
廣告
© . All rights reserved.