Heim > Fragen und Antworten > Hauptteil
Wie man den Aufenthalt vermeidet friends
上重复,我仍然得到两个 bob
,而不是只有一个 bob
Mein Tischaufbau:
CREATE TABLE users( id INT PRIMARY KEY AUTO_INCREMENT, name VARCHAR(255) ); INSERT INTO users (id, name) VALUES (1, "Gregor"), (2, "Liza"), (3, "Matt"), (4, "Tim"), (5, "Lance"), (6, "Bob"); CREATE TABLE committee( id INT PRIMARY KEY AUTO_INCREMENT, user_id INT, friend_id INT, member_id INT, FOREIGN KEY (`user_id`) REFERENCES `users` (`id`), FOREIGN KEY (`friend_id`) REFERENCES `users` (`id`), FOREIGN KEY (`member_id`) REFERENCES `users` (`id`) ); INSERT INTO committee (user_id, friend_id, member_id) VALUES (3, 5, 1), (4, 5, 1), (3, 6, 2), (3, 6, 2), (4, 6, 2);
Die von mir verwendete Abfrage:
SELECT DISTINCT u.name, GROUP_CONCAT(f.name) AS friends FROM committee c INNER JOIN users u ON (u.id = c.user_id) INNER JOIN committee c2 ON c2.user_id = c.user_id INNER JOIN users AS f ON (f.id = c2.friend_id) WHERE (c.member_id = 1) GROUP BY u.id;
Aktuelle Ergebnisse:
name friends Matt Lance,Bob,Bob Tim Lance,Bob
Meine Erwartungen:
name friends Matt Lance,Bob Tim Lance,Bob
P粉7060387412024-02-22 00:49:54
您的 u.name 与 f.name 不同
试试这个
SELECT u.name, GROUP_CONCAT(distinct f.name) AS friends FROM committee c INNER JOIN users u ON (u.id = c.user_id) INNER JOIN committee c2 ON c2.user_id = c.user_id INNER JOIN users AS f ON (f.id = c2.friend_id) WHERE (c.member_id = 1) GROUP BY u.name;
P粉7148447432024-02-22 00:23:39
您只需要在 GROUP_CONCAT()
中使用 DISTINCT
:
SELECT u.name, GROUP_CONCAT(DISTINCT f.name) AS friends ................................................
请注意,SELECT DISTINCT ...
在您的查询中没有意义,因为您使用的是 GROUP BY
,它为每个用户返回不同的行。
查看演示。