zoukankan      html  css  js  c++  java
  • 【转】group_concat函数详解

    转自: http://hchmsguo.iteye.com/blog/555543

    问了好多人,都不知道group_concat这个函数。

     

    这个函数好啊,能将相同的行组合起来,省老事了。

     

    MySQL中group_concat函数


    完整的语法如下:


    group_concat([DISTINCT] 要连接的字段 [Order BY ASC/DESC 排序字段] [Separator '分隔符'])

     

    基本查询

     

    Sql代码  收藏代码
    1. select * from aa;  


    +------+------+
    | id| name |
    +------+------+
    |1 | 10|
    |1 | 20|
    |1 | 20|
    |2 | 20|
    |3 | 200 |
    |3 | 500 |
    +------+------+
    6 rows in set (0.00 sec)

     

    以id分组,把name字段的值打印在一行,逗号分隔(默认)

     

    Sql代码  收藏代码
    1. select id,group_concat(namefrom aa group by id;  


    +------+--------------------+
    | id| group_concat(name) |
    +------+--------------------+
    |1 | 10,20,20|
    |2 | 20 |
    |3 | 200,500|
    +------+--------------------+
    3 rows in set (0.00 sec)

     

    以id分组,把name字段的值打印在一行,分号分隔

     

    Java代码  收藏代码
    1. select id,group_concat(name separator ';') from aa group by id;  


    +------+----------------------------------+
    | id| group_concat(name separator ';') |
    +------+----------------------------------+
    |1 | 10;20;20 |
    |2 | 20|
    |3 | 200;500 |
    +------+----------------------------------+
    3 rows in set (0.00 sec)

     

    以id分组,把去冗余的name字段的值打印在一行,


    逗号分隔

     

    Sql代码  收藏代码
    1. select id,group_concat(distinct namefrom aa group by id;  


    +------+-----------------------------+
    | id| group_concat(distinct name) |
    +------+-----------------------------+
    |1 | 10,20|
    |2 | 20 |
    |3 | 200,500 |
    +------+-----------------------------+
    3 rows in set (0.00 sec)

     

    以id分组,把name字段的值打印在一行,逗号分隔,以name排倒序

     

    Sql代码  收藏代码
    1. select id,group_concat(name order by name descfrom aa group by id;  


    +------+---------------------------------------+
    | id| group_concat(name order by name desc) |
    +------+---------------------------------------+
    |1 | 20,20,10 |
    |2 | 20|
    |3 | 500,200|
    +------+---------------------------------------+
    3 rows in set (0.00 sec)

     

    测试sql,项目中用到的。

    Sql代码  收藏代码
      1. SELECT  
      2.         EMPLOYEES.EMPID  
      3.         ,EMPLOYEES.EMPNAME  
      4.         ,DEPARTMENTS.DEPARTMENTNAME  
      5.         ,EMPLOYEES.DEPTID  
      6.         ,EMPLOYEES.EMPPWD  
      7.         ,EMPLOYEES.INSIDEEMAIL  
      8.         ,EMPLOYEES.OUTSIDEEMAIL  
      9.         ,EMPLOYEES.DELEFLAG  
      10.         ,EMPLOYEES.EMPCLASS  
      11.         ,(CONCAT('[', <span style="color: #ff0000;">GROUP_CONCAT</span>  
      12. (ROLE.Role_Name SEPARATOR '],['), ']')) AS ROLENAME  
      13.         ,(concat( '[', (  
      14.             SELECT  
      15.                     <span style="color: #ff0000;">GROUP_CONCAT</span>  
      16. (DEPARTMENTS.DEPARTMENTNAME separator '],[')  
      17.                 FROM  
      18.                     EMP_ROLE_DEPT  
      19.                         LEFT JOIN DEPARTMENTS  
      20.                             ON (  
      21.                                 DEPARTMENTS.DEPARTMENTID = EMP_ROLE_DEPT.DEPTID  
      22.                                 AND DEPARTMENTS.DELEFLAG = 0  
      23.                             )  
      24.                 GROUP BY  
      25.                     EMP_ROLE_DEPT.EMPID  
      26.                 HAVING  
      27.                     EMP_ROLE_DEPT.EMPID = EMPLOYEES.EMPID  
      28.         ),']')) AS DEPARTMENTRIGHT  
      29.     FROM  
      30.         EMPLOYEES  
      31.             LEFT JOIN DEPARTMENTS  
      32.                 ON (  
      33.                     DEPARTMENTS.DEPARTMENTID = EMPLOYEES.DEPTID  
      34.                     AND DEPARTMENTS.DELEFLAG = 0  
      35.                 )  
      36.             LEFT JOIN ROLE_EMP  
      37.                 ON (ROLE_EMP.EMP_ID = EMPLOYEES.EMPID)  
      38.             LEFT JOIN ROLE  
      39.                 ON (ROLE_EMP.ROLE_ID = ROLE.ROLE_ID)  
      40. <span style="color: #ff0000;">    GROUP BY  
      41.         EMPLOYEES.EMPID</span>  
      42.   
      43.     HAVING  
      44.         EMPLOYEES.EMPID LIKE '%%'  
      45.         AND EMPLOYEES.EMPNAME LIKE '%%'  
      46.         AND EMPLOYEES.DELEFLAG = 0  
      47.         AND (  
      48.             EMPLOYEES.EMPCLASS = '1'  
      49.             OR EMPLOYEES.EMPCLASS = '2'  
      50.         )  
      51.         AND EMPLOYEES.DEPTID = '001' LIMIT 0  
      52.         ,16   
  • 相关阅读:
    解决shiro多次从redis读取session的问题
    软件测试其他方法
    异常HTTP Status 500
    支付
    java面试
    SQL入门
    软件测试理论基础
    软件测试学习第一章
    Linux在终端命令行模式下智能补全功能以及组合键
    Linux安装
  • 原文地址:https://www.cnblogs.com/Athrun/p/3524525.html
Copyright © 2011-2022 走看看