我有 3 个 mysql 表(动物、类别和 animal_2_category)。 每个动物都可以有 0-n 个类别(例如鱼、宠物、昆虫、食肉动物、“会飞”等)。
表“动物”(id、名称)
1, dog
2, cat
3, bee
...
表“类别”(id、名称)
1, pet
2, insect
3, mammal
4, fish
5, can fly
...
表“animal_2_category”(animal_id、category_id)
1, 1
1, 3
2, 1
2, 3
3, 2
3, 5
...
我现在需要的是所有类别组合的列表。 以下查询有效:
SELECT CONCAT_WS("-", x.name, c.name)
FROM animal_2_category a2c1
JOIN animal_2_category a2c2 ON a2c1.animal_id = a2c2.animal_id
JOIN category c ON c.id = a2c2.category_id´
JOIN categories x
GROUP BY a2c2.category_id
此查询将返回以下内容:
- 宠物哺乳动物
- 哺乳动物-宠物
- 昆虫能飞
问题是,我得到了重复的条目“pet-mammal”和“mammal-pet”。 我怎样才能修改查询,只得到其中之一,例如:
- 宠物哺乳动物
- 昆虫能飞
最佳答案
您还可以将查询重写为
SELECT DISTINCT GREATEST(CONCAT_WS("-", x.name, c.name),CONCAT_WS("-", c.name, x.name)) col
FROM animal_2_category a2c1
JOIN animal_2_category a2c2 ON a2c1.animal_id = a2c2.animal_id
JOIN categories c ON c.id = a2c2.`category_id`
JOIN categories `x` ON a2c1.category_id = x.id
WHERE x.name <> c.name
关于php - Mysql排序连接值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29941921/