如何在MySQL中使用GROUP_CONCAT和CONCAT与DISTINCT引用单列值?

为此,您可以将group_concat()与一起使用replace()。让我们首先创建一个表-

mysql> create table DemoTable1799
     (
     EmployeeId varchar(20)
     );

使用插入命令在表中插入一些记录-

mysql> insert into DemoTable1799 values('101,102,103,104');
mysql> insert into DemoTable1799 values('106,109');

使用select语句显示表中的所有记录-

mysql> select * from DemoTable1799;

这将产生以下输出:

+-----------------+
| EmployeeId      |
+-----------------+
| 101,102,103,104 |
| 106,109         |
+-----------------+
2 rows in set (0.00 sec)

这是查询使用group_concat和concat引用单列值的方法,其中-

mysql> select group_concat(distinct concat("'", replace(EmployeeId, "," , "','") , "'")) as Output from DemoTable1799;

这将产生以下输出-

+-------------------------------------+
| Output                              |
+-------------------------------------+
| '101','102','103','104','106','109' |
+-------------------------------------+
1 row in set (0.00 sec)