【问题标题】: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。

标签: mysql sql database select


【解决方案1】:

感谢@jarlh 建议使用组 concat(不知道这样的功能)。

在这种情况下(对于 MySQL)的解决方案是:

select distinct group_concat(preferred_color)
  from my_table
  group by person_id

【讨论】:

  • 你怎么知道哪个组属于哪个人?
  • @Strawberry 我不知道;只有所有可能的组。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2017-01-24
  • 1970-01-01
  • 2018-08-22
  • 2021-09-07
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多