[英]MySQL concat multiple rows into a single row
我有一个查询返回MySQL中的多行,如下所示:
attribute_name value
----------------------------------------
username emailuser
domain mydomain.com
我的要求输出如下:
username domain
-----------------------------
emailuser mydomain.com
当前的SQL:
SELECT pa2.attribute_name, upa2.value
FROM product p
INNER JOIN product_attribute pa ON p.product_id = pa.product_id
AND pa.attribute_name = 'alias'
INNER JOIN user_product_attribute upa ON pa.product_attribute_id upa.product_attribute_id
INNER JOIN user_product_attribute upa2 ON upa.user_product_id = upa2.user_product_id
INNER JOIN product_attribute pa2 ON pa2.product_attribute_id = upa2.product_attribute_id
AND pa2.attribute_name
IN (
'username', 'domain'
)
WHERE p.product_name = 'email'
AND upa.value = 'emailalias@domainalias'
我一直在看group_concat,但我认为这是错误的道路..有什么建议吗?
group_concat
。 以下查询将会很慢,但对于一个小表,这可能并不重要。
SELECT
GROUP_CONCAT(IF(`attribute_name`='username', `value`,'')) AS `username`,
GROUP_CONCAT(IF(`attribute_name`='domain', `value`, '')) AS `domain`,
FROM (your old table or the select query)
GROUP BY `attribute_name`
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.