我有下面的查询,应该可以。但是,MySQL 给了我错误消息“子查询返回多行”。
select e.episode_pk,
(select group_concat(d.fulldescription separator ', ')
from episode_rhythm er join diagnosis d on er.diagnosis_fk = d.diagnosis_pk
WHERE er.episode_fk = e.episode_pk group by d.fulldescription) as rhythmDesc
from episode e
WHERE e.patientid_fk='89976'
在此查询中使用 group_concat 的全部目的是每个“剧集”仅返回一行。
外部选择返回多行。
内部选择在针对单个剧集表主键运行时,会返回您可能怀疑的单行:
select group_concat(d.fulldescription separator ', ')
from episode_rhythm er join diagnosis d on er.diagnosis_fk = d.diagnosis_pk
WHERE er.episode_fk = 234776 group by d.fulldescription
没有 group_concat 的内部选择,当针对单个剧集表主键运行时,可能会返回多行:
select d.fulldescription
from episode_rhythm er join diagnosis d on er.diagnosis_fk = d.diagnosis_pk
WHERE er.episode_fk = 234776
我需要做些什么才能使其按预期工作?