在多对多关系中选择所有唯一的可能(多个)值?
Posted
技术标签:
【中文标题】在多对多关系中选择所有唯一的可能(多个)值?【英文标题】:Select all unique possible (multiple) values in a many-to-many relationship? 【发布时间】:2018-01-29 15:01:39 【问题描述】:假设有一个简单的表,比如多对多关系。
person_id | preferred_color
-------------------
1 | BLUE
1 | RED
2 | BLUE
3 | BLUE
3 | RED
4 | BLUE
5 | BLUE
5 | RED
5 | GREEN
6 | RED
6 | GREEN
我想要的是一个 SQL 查询来返回多对多关系中的所有可能值;对于给定的示例,一个人所有可能最喜欢的颜色:[(BLUE, RED), (BLUE), (BLUE,RED,GREEN), (RED, GREEN)]。
通过简单的选择,只选择一种首选颜色的可能性非常容易;即使有两个两个首选的颜色也是可能的,带有一个自我连接。但是有不同数量的首选颜色?
【问题讨论】:
GROUP BY, GROUP_CONCAT @jarlh 谢谢。它适用于组 concat。 【参考方案1】:感谢@jarlh 建议使用组 concat(不知道这样的功能)。
在这种情况下(对于 mysql)的解决方案是:
select distinct group_concat(preferred_color)
from my_table
group by person_id
【讨论】:
你怎么知道哪个组属于哪个人? @Strawberry 我不知道;只有所有可能的组。以上是关于在多对多关系中选择所有唯一的可能(多个)值?的主要内容,如果未能解决你的问题,请参考以下文章