如何连接mysql中单列的所有值

Posted

技术标签:

【中文标题】如何连接mysql中单列的所有值【英文标题】:How to concat all values of single column in mysql 【发布时间】:2017-02-21 03:43:43 【问题描述】:

我在示例表 1 中有 A 列。 A 列的值如下。

+----+
| A  |
+----+
| a1 |
| a2 |
| a3 |
| a4 |
| a5 |
+----+

我需要一个应该给出以下输出的查询。 所有的值都应该是

"a1","a2","a3","a4","a5"

有办法吗?

【问题讨论】:

【参考方案1】:

您可以使用 CONCATGROUP_CONCAT

的组合

查询

SELECT GROUP_CONCAT(CONCAT('"', A, '"')) AS `combined_A`
FROM `your_table_name`;

如果您想删除重复项。然后使用DISTINCTGROUP_CONCAT

查询

SELECT GROUP_CONCAT(DISTINCT CONCAT('"', `A`, '"')) AS `combined_A`
FROM `your_table_name`;

SQL Fiddle demo

【讨论】:

如果我需要a1&a2&a3&a4&a5(中间没有,)怎么办? @June : 你可以使用separator '&'Group_Concat【参考方案2】:

使用 GROUP_CONCAT() 函数来实现。

SELECT GROUP_CONCAT(<Type your column name here> SEPARATOR ', ') FROM <Table Name>;

查询您提供的示例:

SELECT GROUP_CONCAT(A SEPARATOR ', ')  FROM Table1;

【讨论】:

【参考方案3】:

你必须使用group concat 函数来完成类似的事情

SELECT , GROUP_CONCAT(A SEPARATOR ', ') FROM Table1 分组依据

如果您没有 id,则必须使用常量进行分组。另请注意,您的结果有 1024 字节字符限制unless you override it

【讨论】:

在这个实例中没有 GROUP BY

以上是关于如何连接mysql中单列的所有值的主要内容,如果未能解决你的问题,请参考以下文章

用sqlyog写mysql代码。A表为总表,B表A表一部分,查询A表中多余B表的部分。表是单列的?

MySQL 多表查询

如何使用 MySQL 连接语句选择与链接表中的多个值匹配的记录?

如何将android与php mysql连接[重复]

如何在单个字段或列中连接多个值? (MySQL)

使用java更新具有单列的mysql数据