【发布时间】:2021-11-27 18:24:45
【问题描述】:
我对以下查询有一个奇怪的问题:
SELECT
doubles_team_members.doubles_team_id,
GROUP_CONCAT(CONCAT(members.first_name,' ',members.last_name) SEPARATOR ' & ') team,
GROUP_CONCAT(DISTINCT CONCAT(members.city,', ',members.state) SEPARATOR ' & ') location,
doubles_teams.deleted_by_id
FROM
doubles_team_members
JOIN
doubles_teams USING(doubles_team_id)
JOIN
members USING(member_id)
JOIN
memberships ON members.member_id=memberships.member_id
WHERE
(memberships.expiration_date>=CURDATE() OR members.lifetime=1) AND
(doubles_teams.deleted_by_id IS NULL OR doubles_teams.deleted_by_id=0) AND
(members.deleted_by_id IS NULL OR members.deleted_by_id=0)
GROUP BY
doubles_team_members.doubles_team_id
HAVING
team='Van Williams & Derek Williams';
有时我会得到零、一、二或三个结果。我应该总是得到三个结果。这可能是什么原因造成的?
【问题讨论】:
-
你能添加一些数据吗?另外,“有时”到底是什么意思?比如,当您连续两次运行查询时,或者更确切地说,一天是两条,另一天是结果中的三条记录?
-
需要考虑的事情:您的 group_concat 没有固有的顺序。如果 MySQL 以不同的方式随机排序您的成员(例如 derek first),则 having 子句可能不匹配。
标签: mysql sql sql-order-by group-concat