繁体   English   中英

MySQL Group_Concat按ID区分

[英]MySQL Group_Concat Distinct By Id

是否可以通过不同的id对group_concat记录:

GROUP_CONCAT(Column2 BY DISTINCT Column1)

我需要通过column1的不同值来获取column2的值。 因为第2列中有重复的值,所以我不能在column2上使用distinct。

有什么想法吗? 谢谢!

编辑1

样本表记录:

ID  Value
1   A
1   A
2   B
3   B
4   C
4   C

使用我想要的GROUP_CONCAT [ GROUP_CONCAT(Value BY DISTINCT Id) ],我将得到一个输出:

A, B, B, C

编辑2

不知何故让我的group_concat工作:

GROUP_CONCAT(DISTINCT CONCAT(Id, '|', Value))

这将通过不同的ID显示连接的值,只需要删除某个地方的ID即可。 您可以在没有concat函数的情况下执行此操作,但是我需要使用分隔符。 这可能不是一个好答案,但是我还是会发布它。

试试这个,( 最简单的方法

SELECT GROUP_CONCAT(VALUE)
FROM
(
    SELECT DISTINCT ID, VALUE
    FROM TableName
) a

SQLFiddle演示

GROUP_CONCAT函数支持DISTINCT表达式。

SELECT id, GROUP_CONCAT(DISTINCT value) FROM table_name GROUP BY id

这应该工作:

SELECT GROUP_CONCAT(value) FROM (SELECT id, value FROM table GROUP BY id, value) AS d

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM