[英]Select all unique possible (multiple) values in a many-to-many relationship?
假设有一个简单的表,如多对多关系。
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查询,以从多对多关系中返回所有可能的值; 对于给定的示例,一个人所有可能喜欢的颜色:[(蓝色,红色),(蓝色),(蓝色,红色,绿色),(红色,绿色)]。
通过简单的选择,仅选择一种首选颜色的可能性就非常容易。 甚至具有两个两个首选的颜色也是可能的,带有自连接。 但是具有不同数量的首选颜色?
感谢@jarlh提出使用组concat的建议(不知道此类功能)。
在这种情况下(对于MySQL)的解决方案是:
select distinct group_concat(preferred_color)
from my_table
group by person_id
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.