一个有两个表。一个是注册人,另一个是自定义字段,它们通过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/

10-16 13:14
查看更多