A有两张桌子。其中一个是注册人,另一个是自定义字段,它们通过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中用;
分隔列答案 0 :(得分:3)
您的问题的答案是函数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
(即使您的示例只返回一行)。