一个有两个表。一个是注册人,另一个是自定义字段,它们通过id连接。
例如
表格1
id name email
1 John aaa@aaa.com
表2
field id registrant id value
1 1 Yes
2 1 Have dog
我想连接这些表,并使用此查询
SELECT `jos_eb_registrants`. * , `jos_eb_field_values`. *
FROM jos_eb_registrants, jos_eb_field_values
WHERE `jos_eb_registrants`.`event_id` =3
AND `jos_eb_registrants`.`id` = `jos_eb_field_values`.`registrant_id`
得到这个结果
John aaa@aaa.com Yes
John aaa@aaa.com Have dog
我要这个 -
John aaa@aaa.com Yes Have dog
并用csv分隔列;
最佳答案
您的问题的答案是函数group_concat()
:
SELECT r.name, r.email,
group_concat(`value` separator ' ') as `values`
FROM jos_eb_registrants r join
jos_eb_field_values v
on v.`id` = v.`registrant_id`
WHERE r.`event_id` =3
group by r.name, r.email ;
该查询还引入了表别名,以使查询更具可读性。它使用正确的ANSI
join
语法,并添加了显式的group by
(即使您的示例仅返回一行)。关于mysql - 在MySQL中消除SQL查询重复项,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/21676969/