首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何对字段数据进行分组?

如何对字段数据进行分组?
EN

Stack Overflow用户
提问于 2013-05-03 10:58:23
回答 2查看 91关注 0票数 1

我使用sql查询来显示数据

代码语言:javascript
复制
"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查询的查询结果

代码语言:javascript
复制
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        |

如何对字段进行分组,如

代码语言:javascript
复制
Name  | email           | customer | invoice id|
Lekto | lekto@gmail.com | edwin    | 11        |
      |                 | risa     | 12        |
      |                 | edwin    | 13        |
heko  | heko@gmail.com  | pae      | 15        |
      |                 | edwin    | 16        |

请帮助显示如下查询

EN

回答 2

Stack Overflow用户

发布于 2013-05-03 11:34:35

这是一个奇怪的问题,但是如果您在MySQL中确实需要这样做,那么您可以使用用户变量将列表中的子项的Nameemail列设置为'‘(空字符串)。

或例如

代码语言:javascript
复制
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变量,以防您无法控制它们。

票数 1
EN

Stack Overflow用户

发布于 2013-05-03 11:47:21

在mysql中你可以做的一件事就是用group bygroup_concat()包装你的查询。如下所示:

代码语言:javascript
复制
SELECT
    name, 
    email, 
    group_concat(customer) AS customers, 
    group_concat(invoice_id) AS invoice_ids
FROM
    (...query you already have..)
GROUP BY
    name, email

结果将如下所示:

代码语言:javascript
复制
name    email               customers           invoice_ids

heko    heko@gmail.com      pae,edwin           15,16
Lekto   lekto@gmail.com     edwin,risa,edwin    11,12,13

PLZ SEE FIDDLE

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16350897

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档