我使用sql查询来显示数据
"SELECT
`artikel`.`foto_naam`,
`fotografer`.`id`,
`fotografer`.`name_fotografer`,
`customer`.`first_name`,
`customer`.`last_name`,
`fotografer`.`domain_name`,
`fotografer`.`email`,
`order`.`invoice_no`,
`order`.`order_cost`,
`order`.`total_cost`,
`order`.`invoice_date`,
`order`.`payment`,
`order`.`status`
FROM
`artikel_group`
INNER JOIN `artikel` ON `artikel`.`artikelgroup_id` = `artikel_group`.`id`
INNER JOIN `fotografer` ON `artikel_group`.`fotografer_id` = `fotografer`.`id`
INNER JOIN `order_has_artikelgroup` ON `order_has_artikelgroup`.`artikelgroup_id` = `artikel_group`.`id`
INNER JOIN `order` ON `order`.`id` = `order_has_artikelgroup`.`order_id`
INNER JOIN `customer` ON `order`.`customer_id` = `customer`.`id`"我使用php框架codeigniter对我的sql查询的查询结果
Name | email | customer | invoice id|
Lekto | lekto@gmail.com | edwin | 11 |
Lekto | lekto@gmail.com | risa | 12 |
Lekto | lekto@gmail.com | edwin | 13 |
heko | heko@gmail.com | pae | 15 |
heko | heko@gmail.com | edwin | 16 |如何对字段进行分组,如
Name | email | customer | invoice id|
Lekto | lekto@gmail.com | edwin | 11 |
| | risa | 12 |
| | edwin | 13 |
heko | heko@gmail.com | pae | 15 |
| | edwin | 16 |请帮助显示如下查询
发布于 2013-05-03 11:34:35
这是一个奇怪的问题,但是如果您在MySQL中确实需要这样做,那么您可以使用用户变量将列表中的子项的Name和email列设置为'‘(空字符串)。
或例如
select
if(@tName!= Name, if(@'tNAME':= Name, Name,Name) , '' ),
if(@tEmail!= Email, if(@'tEmail':= Email, Email ,Email) , '' ),
customer,
invoice_id,
/* blah blah blah */
from
tables
join (select @'tName':='', @'tEmail':='') T on 1=1
/* blah blah blah */我提供了join (select @'tName':='') T on 1=1来重新初始化user变量,以防您无法控制它们。
发布于 2013-05-03 11:47:21
在mysql中你可以做的一件事就是用group by和group_concat()包装你的查询。如下所示:
SELECT
name,
email,
group_concat(customer) AS customers,
group_concat(invoice_id) AS invoice_ids
FROM
(...query you already have..)
GROUP BY
name, email结果将如下所示:
name email customers invoice_ids
heko heko@gmail.com pae,edwin 15,16
Lekto lekto@gmail.com edwin,risa,edwin 11,12,13PLZ SEE FIDDLE
https://stackoverflow.com/questions/16350897
复制相似问题