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

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

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

MySQL中group_concat函数

完整的语法如下:

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

基本查询

  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字段的值打印在一行,逗号分隔(默认)

  1. select id,group_concat(name) from 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字段的值打印在一行,分号分隔

  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字段的值打印在一行,

逗号分隔

  1. select id,group_concat(distinct name) from 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排倒序

  1. select id,group_concat(name order by name desc) from 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,项目中用到的。

    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. HAVING
    43. EMPLOYEES.EMPID LIKE '%%'
    44. AND EMPLOYEES.EMPNAME LIKE '%%'
    45. AND EMPLOYEES.DELEFLAG = 0
    46. AND (
    47. EMPLOYEES.EMPCLASS = '1'
    48. OR EMPLOYEES.EMPCLASS = '2'
    49. )
    50. AND EMPLOYEES.DEPTID = '001' LIMIT 0
    51. ,16

【转】group_concat函数详解的更多相关文章

  1. group_concat函数详解

    来自: http://hchmsguo.iteye.com/blog/555543 MySQL中group_concat函数 完整的语法如下: group_concat([DISTINCT] 要连接的 ...

  2. 转 group_concat函数详解

    MySQL中group_concat函数 完整的语法如下: group_concat([DISTINCT] 要连接的字段 [Order BY ASC/DESC 排序字段] [Separator '分隔 ...

  3. mysql之group_concat函数详解

    函数语法: group_concat( [DISTINCT]  要连接的字段   [Order BY 排序字段 ASC/DESC]   [Separator '分隔符'] ) 下面举例说明: sele ...

  4. Mysql中关于 group_concat函数详解

    group_concat()主要功能:能将相同的行组合起来 完整的语法如下: group_concat([DISTINCT] 要连接的字段 [Order BY ASC/DESC 排序字段] [Sepa ...

  5. mysql group_concat函数详解

    group_concat( [DISTINCT]  要连接的字段   [Order BY 排序字段 ASC/DESC]   [Separator '分隔符'] ) 1. --以id分组,把price字 ...

  6. malloc 与 free函数详解<转载>

    malloc和free函数详解   本文介绍malloc和free函数的内容. 在C中,对内存的管理是相当重要.下面开始介绍这两个函数: 一.malloc()和free()的基本概念以及基本用法: 1 ...

  7. NSSearchPathForDirectoriesInDomains函数详解

    NSSearchPathForDirectoriesInDomains函数详解     #import "NSString+FilePath.h" @implementation ...

  8. JavaScript正则表达式详解(二)JavaScript中正则表达式函数详解

    二.JavaScript中正则表达式函数详解(exec, test, match, replace, search, split) 1.使用正则表达式的方法去匹配查找字符串 1.1. exec方法详解 ...

  9. Linux C popen()函数详解

    表头文件 #include<stdio.h> 定义函数 FILE * popen( const char * command,const char * type); 函数说明 popen( ...

随机推荐

  1. sqoop1.4.6数据迁移

    sqoop介绍 sqoop是apache旗下一款“Hadoop和关系数据库服务器之间传送数据”的工具. 导入数据:MySQL,Oracle导入数据到Hadoop的HDFS.HIVE.HBASE等数据存 ...

  2. maven中的各种问题

    [ERROR] Plugin org.apache.maven.plugins:maven-shade-plugin:3.1 or one of its dependencies could not ...

  3. 【Ubuntu】Ubuntu设置和查看环境变量

    [Ubuntu]Ubuntu设置和查看环境变量    转载 https://blog.csdn.net/White_Idiot/article/details/78253004 1. 查看环境变量 查 ...

  4. MarginTop 为何影响父元素的 MarginTop(转)

    add by zhj: 没找到原文 这个问题困惑了很久,虽然没有大碍早就摸出来怎么搞定它,但始终不明白原因出在哪里,如果只是IE有问题我也不会太在意,可问题是所有上等浏览器都表现如此,这样叫我怎能安心 ...

  5. 《Population Based Training of Neural Networks》论文解读

      很早之前看到这篇文章的时候,觉得这篇文章的思想很朴素,没有让人眼前一亮的东西就没有太在意.之后读到很多Multi-Agent或者并行训练的文章,都会提到这个算法,比如第一视角多人游戏(Quake ...

  6. opesntack 底层共享存储 迁移配置

    底层共享存储在迁移配置: 每台compute 节点都需要配置一下 让nova用户可以登陆 usermod -s /bin/bash nova 设置nova 用户密码 echo "nova&q ...

  7. BZOJ.3680.吊打XXX(模拟退火/爬山算法)

    题目链接 一个比较好的解释? 模拟退火(Simulated Annealing,SA): (1)初始化一个温度(充分大).初始解状态S.每个T值的迭代次数. (2)对i=1,...,L,做(3)至(7 ...

  8. BZOJ2924 : [Poi1998]Flat broken lines

    首先旋转坐标系 $x'=x-y$ $y'=-x-y$ 则对于一个点,它下一步可以往它左上角任意一个点连线. 根据Dilworth定理,答案=这个偏序集最长反链的长度. 设f[i]为到i点为止的最长反链 ...

  9. 数据库事务的属性-ACID和隔离级别

    1.数据库事务的属性-ACID(四个英文单词的首写字母): 1)原子性(Atomicity) 所谓原子性就是将一组操作作为一个操作单元,是原子操作,即要么全部执行,要么全部不执行. 2)一致性(Con ...

  10. [廖雪峰] Git 分支管理(3):分支管理策略

    通常,合并分支时,如果可能,Git 会用 Fast forward 模式,但这种模式下,删除分支后,会丢掉分支信息. 如果要强制 禁用 Fast forward 模式,Git 就会在 merge 时生 ...