【转】group_concat函数详解
转自: http://hchmsguo.iteye.com/blog/555543
问了好多人,都不知道group_concat这个函数。
这个函数好啊,能将相同的行组合起来,省老事了。
MySQL中group_concat函数
完整的语法如下:
group_concat([DISTINCT] 要连接的字段 [Order BY ASC/DESC 排序字段] [Separator '分隔符'])
基本查询
- 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字段的值打印在一行,逗号分隔(默认)
- 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字段的值打印在一行,分号分隔
- 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字段的值打印在一行,
逗号分隔
- 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排倒序
- 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,项目中用到的。
- SELECT
- EMPLOYEES.EMPID
- ,EMPLOYEES.EMPNAME
- ,DEPARTMENTS.DEPARTMENTNAME
- ,EMPLOYEES.DEPTID
- ,EMPLOYEES.EMPPWD
- ,EMPLOYEES.INSIDEEMAIL
- ,EMPLOYEES.OUTSIDEEMAIL
- ,EMPLOYEES.DELEFLAG
- ,EMPLOYEES.EMPCLASS
- ,(CONCAT('[', <span style="color: #ff0000;">GROUP_CONCAT</span>
- (ROLE.Role_Name SEPARATOR '],['), ']')) AS ROLENAME
- ,(concat( '[', (
- SELECT
- <span style="color: #ff0000;">GROUP_CONCAT</span>
- (DEPARTMENTS.DEPARTMENTNAME separator '],[')
- FROM
- EMP_ROLE_DEPT
- LEFT JOIN DEPARTMENTS
- ON (
- DEPARTMENTS.DEPARTMENTID = EMP_ROLE_DEPT.DEPTID
- AND DEPARTMENTS.DELEFLAG = 0
- )
- GROUP BY
- EMP_ROLE_DEPT.EMPID
- HAVING
- EMP_ROLE_DEPT.EMPID = EMPLOYEES.EMPID
- ),']')) AS DEPARTMENTRIGHT
- FROM
- EMPLOYEES
- LEFT JOIN DEPARTMENTS
- ON (
- DEPARTMENTS.DEPARTMENTID = EMPLOYEES.DEPTID
- AND DEPARTMENTS.DELEFLAG = 0
- )
- LEFT JOIN ROLE_EMP
- ON (ROLE_EMP.EMP_ID = EMPLOYEES.EMPID)
- LEFT JOIN ROLE
- ON (ROLE_EMP.ROLE_ID = ROLE.ROLE_ID)
- <span style="color: #ff0000;"> GROUP BY
- EMPLOYEES.EMPID</span>
- HAVING
- EMPLOYEES.EMPID LIKE '%%'
- AND EMPLOYEES.EMPNAME LIKE '%%'
- AND EMPLOYEES.DELEFLAG = 0
- AND (
- EMPLOYEES.EMPCLASS = '1'
- OR EMPLOYEES.EMPCLASS = '2'
- )
- AND EMPLOYEES.DEPTID = '001' LIMIT 0
- ,16
【转】group_concat函数详解的更多相关文章
- group_concat函数详解
来自: http://hchmsguo.iteye.com/blog/555543 MySQL中group_concat函数 完整的语法如下: group_concat([DISTINCT] 要连接的 ...
- 转 group_concat函数详解
MySQL中group_concat函数 完整的语法如下: group_concat([DISTINCT] 要连接的字段 [Order BY ASC/DESC 排序字段] [Separator '分隔 ...
- mysql之group_concat函数详解
函数语法: group_concat( [DISTINCT] 要连接的字段 [Order BY 排序字段 ASC/DESC] [Separator '分隔符'] ) 下面举例说明: sele ...
- Mysql中关于 group_concat函数详解
group_concat()主要功能:能将相同的行组合起来 完整的语法如下: group_concat([DISTINCT] 要连接的字段 [Order BY ASC/DESC 排序字段] [Sepa ...
- mysql group_concat函数详解
group_concat( [DISTINCT] 要连接的字段 [Order BY 排序字段 ASC/DESC] [Separator '分隔符'] ) 1. --以id分组,把price字 ...
- malloc 与 free函数详解<转载>
malloc和free函数详解 本文介绍malloc和free函数的内容. 在C中,对内存的管理是相当重要.下面开始介绍这两个函数: 一.malloc()和free()的基本概念以及基本用法: 1 ...
- NSSearchPathForDirectoriesInDomains函数详解
NSSearchPathForDirectoriesInDomains函数详解 #import "NSString+FilePath.h" @implementation ...
- JavaScript正则表达式详解(二)JavaScript中正则表达式函数详解
二.JavaScript中正则表达式函数详解(exec, test, match, replace, search, split) 1.使用正则表达式的方法去匹配查找字符串 1.1. exec方法详解 ...
- Linux C popen()函数详解
表头文件 #include<stdio.h> 定义函数 FILE * popen( const char * command,const char * type); 函数说明 popen( ...
随机推荐
- PHP获取访问者公网IP
if(!empty($_SERVER["HTTP_CLIENT_IP"])){ $cip = $_SERVER["HTTP_CLIENT_IP"]; } el ...
- pip 安装包提速
豆瓣源 pip3 install 第三方库名 -i https://pypi.doubanio.com/simple/ --trusted-host pypi.doubanio.com
- .NET工作准备--02基础知识
(已过时) 框架基础,语法基础,字符串&集合&流,常见类和接口; 02.net基础(重点) -第一部分 框架基础 1.基础概念 CTS(Common Type System),CLS( ...
- 使用Synchronized块同步方法
synchronized关键字有两种用法.第一种就是在<使用Synchronized关键字同步类方法>一文中所介绍的直接用在方法的定义中.另外一种就是synchronized块.我们不仅可 ...
- Django如何重设Admin密码
如果你忘记了Admin的密码的话,就要用Django shell: python manage.py shell 然后获取你的用户名,并且重设密码: >>>from django.c ...
- MOXA的Nport5600初始密码
今天第一次弄Nport,看了半天手册没找到初始密码,网上也搜不到,按照说明书上想打电话问问,发现根本是空号... 后来灵感一来试了一下,居然是:moxa
- BZOJ 4706: B君的多边形 找规律
4706: B君的多边形 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=4706 Description 有一个正n多边形,我们要连接一些 ...
- Mac安装jdk1.6
需到apple官网下载 下载地址:https://support.apple.com/kb/DL1572?viewlocale=en_US&locale=en_US 相关介绍: http:// ...
- 关于使用react的思考
1. 组件化开发:将可以复用的部分独立封装成一个组件,每个部分的数据互不影响
- OpenVPN推送默认路由表
根据官方Server配置文件:https://github.com/OpenVPN/openvpn/blob/master/sample/sample-config-files/server.conf ...