將具有相同對應 ID 的記錄連線成用特殊字元分隔的單行中的 MySQL 查詢


為此,你可以使用 CONCAT_WS() 和 GROUP_CONCAT()。讓我們首先建立一個

mysql> create table DemoTable2016
   -> (
   -> UserId int,
   -> UserName varchar(20)
   -> );
Query OK, 0 rows affected (0.51 sec)

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

mysql> insert into DemoTable2016 values(1,'Chris');
Query OK, 1 row affected (0.17 sec)

mysql> insert into DemoTable2016 values(2,'Bob');
Query OK, 1 row affected (0.10 sec)

mysql> insert into DemoTable2016 values(1,'David');
Query OK, 1 row affected (0.14 sec)

mysql> insert into DemoTable2016 values(2,'Carol');
Query OK, 1 row affected (0.12 sec)

mysql> insert into DemoTable2016 values(1,'Sam');
Query OK, 1 row affected (0.14 sec)

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

mysql> select *from DemoTable2016;

這將產生以下輸出 -

+--------+----------+
| UserId | UserName |
+--------+----------+
| 1      | Chris    |
| 2      | Bob      |
| 1      | David    |
| 2      | Carol    |
| 1      | Sam      |
+--------+----------+
5 rows in set (0.00 sec)

以下是將一行中記錄(由特殊字元分隔)連線起來的查詢 -

mysql> select group_concat(concat_ws('-',UserName,UserId)) from DemoTable2016 group by UserId;

這將產生以下輸出 -

+----------------------------------------------+
| group_concat(concat_ws('-',UserName,UserId)) |
+----------------------------------------------+
| Chris-1,David-1,Sam-1                        |
| Bob-2,Carol-2                                |
+----------------------------------------------+
2 rows in set (0.00 sec)

更新於: 06-4-2020

229個檢視

開啟你的 職業

完成課程獲得認證

開始吧
廣告