文档章节

关于Mysql group_concat的应用(把相同ID的VAL用字符'/'连接起来)

如比如比
 如比如比
发布于 2015/06/14 16:26
字数 510
阅读 105
收藏 4

关于Mysql group_concat的应用

■事先准备:

CREATE TABLE TBL_GRP_CAT (

ID INT,

VAL CHAR

);


INSERT INTO TBL_GRP_CAT VALUES(1, 'a');

INSERT INTO TBL_GRP_CAT VALUES(1, 'b');

INSERT INTO TBL_GRP_CAT VALUES(1, 'c');

INSERT INTO TBL_GRP_CAT VALUES(2, 'd');

INSERT INTO TBL_GRP_CAT VALUES(2, 'e');

INSERT INTO TBL_GRP_CAT VALUES(2, 'd');

INSERT INTO TBL_GRP_CAT VALUES(2, 'f');


mysql> select * from TBL_GRP_CAT;

+------+------+

| ID   | VAL  |

+------+------+

|    1 | a    |

|    1 | b    |

|    1 | c    |

|    2 | d    |

|    2 | e    |

|    2 | d    |

|    2 | f    |

+------+------+

7 rows in set (0.00 sec)


mysql>


■语法:

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


■示例

示例1:把相同ID的VAL用逗号连接起来(可以重复)

SELECT ID, group_concat(VAL) VAL FROM TBL_GRP_CAT GROUP BY ID ORDER BY ID;

mysql> SELECT ID, group_concat(VAL) VAL FROM TBL_GRP_CAT GROUP BY ID ORDER BY ID

;

+------+---------+

| ID   | VAL     |

+------+---------+

|    1 | a,b,c   |

|    2 | d,e,d,f |

+------+---------+

2 rows in set (0.00 sec)


mysql>


示例2:把相同ID的VAL用逗号连接起来(不含重复)

SELECT ID, group_concat(DISTINCT VAL) VAL FROM TBL_GRP_CAT GROUP BY ID ORDER BY ID;

mysql> SELECT ID, group_concat(DISTINCT VAL) VAL FROM TBL_GRP_CAT GROUP BY ID OR

DER BY ID;

+------+-------+

| ID   | VAL   |

+------+-------+

|    1 | a,b,c |

|    2 | d,e,f |

+------+-------+

2 rows in set (0.00 sec)


mysql>


示例3:把相同ID的VAL由大到小用逗号连接起来(可以重复)

SELECT ID, group_concat(VAL Order BY VAL DESC) VAL FROM TBL_GRP_CAT GROUP BY ID ORDER BY ID;

mysql> SELECT ID, group_concat(VAL Order BY VAL DESC) VAL FROM TBL_GRP_CAT GROU

 BY ID ORDER BY ID;

+------+---------+

| ID   | VAL     |

+------+---------+

|    1 | c,b,a   |

|    2 | f,e,d,d |

+------+---------+

2 rows in set (0.00 sec)


mysql>


示例4:把相同ID的VAL用字符'/'连接起来(可以重复)

SELECT ID, group_concat(VAL Separator '/') VAL FROM TBL_GRP_CAT GROUP BY ID ORDER BY ID;

mysql> SELECT ID, group_concat(VAL Separator '/') VAL FROM TBL_GRP_CAT GROUP BY

ID ORDER BY ID;

+------+---------+

| ID   | VAL     |

+------+---------+

|    1 | a/b/c   |

|    2 | d/e/d/f |

+------+---------+

2 rows in set (0.00 sec)


mysql>


示例5:权使用

SELECT ID, group_concat(DISTINCT VAL Order BY VAL DESC Separator '/') VAL FROM TBL_GRP_CAT GROUP BY ID ORDER BY ID;

mysql> SELECT ID, group_concat(DISTINCT VAL Order BY VAL DESC Separator '/') VAL

 FROM TBL_GRP_CAT GROUP BY ID ORDER BY ID;

+------+-------+

| ID   | VAL   |

+------+-------+

|    1 | c/b/a |

|    2 | f/e/d |

+------+-------+

2 rows in set (0.00 sec)


mysql>


在Oracle(Listagg),Sqlite(group_concat)等均有类似功能。


© 著作权归作者所有

上一篇: go_1
如比如比
粉丝 127
博文 178
码字总数 286951
作品 0
日本
程序员
私信 提问
关于mysql函数GROUP_CONCAT

GROUPCONCAT()是MySQL数据库提供的一个函数,通常跟GROUP BY一起用,具体可参考MySQL官方文挡:http://dev.mysql.com/doc/refman/5.0/en/group-by-functions.html#functiongroup-concat。 语法...

月下独酌100
2016/05/25
26
0
MySQL函数GROUP_CONCAT

该函数返回带有来自一个组的连接的非NULL值的字符串结果。该函数是一个增强的Sybase SQL Anywhere支持的基本LIST()函数。 语法结构: GROUPCONCAT([DISTINCT] expr [,expr ...] [ORDER BY {u...

舆图易稿
2015/01/07
0
0
mysql group_concat合并行用法和问题

还有分隔符还可以自定义,默认是以“,”作为分隔符,若要改为“ ”,则使用SEPARATOR来指定, 例如: mysql> SELECT student_id, GROUP_CONCAT(courses_id SEPARATOR ' ') AS courses FROM s......

豆花饭烧土豆
2016/09/08
15
0
MYSQL中group_concat有长度限制!默认1024

MYSQL中group_concat有长度限制!默认1024 在mysql中,有个函数叫“group_concat”,平常使用可能发现不了问题,在处理大数据的时候,会发现内容被截取了, 其实MYSQL内部对这个是有设置的,...

风中帆
2016/05/19
531
0
MySQL中group_concat 函数

解释 --- 用在 分组的时候,连接多行的字段拼接在一起。 语法 --- 完整的语法如下: 演示 表数据如下: 把name字段的值打印在一行,逗号分隔(默认) 处理1:合并字段到一行 执行SQL: 运行结果...

echojson
04/18
24
0

没有更多内容

加载失败,请刷新页面

加载更多

64.监控平台介绍 安装zabbix 忘记admin密码

19.1 Linux监控平台介绍 19.2 zabbix监控介绍 19.3/19.4/19.6 安装zabbix 19.5 忘记Admin密码如何做 19.1 Linux监控平台介绍: 常见开源监控软件 ~1.cacti、nagios、zabbix、smokeping、ope...

oschina130111
今天
13
0
当餐饮遇上大数据,嗯真香!

之前去开了一场会,主题是「餐饮领袖新零售峰会」。认真听完了餐饮前辈和新秀们的分享,觉得获益匪浅,把脑子里的核心纪要整理了一下,今天和大家做一个简单的分享,欢迎感兴趣的小伙伴一起交...

数澜科技
今天
7
0
DNS-over-HTTPS 的下一代是 DNS ON BLOCKCHAIN

本文作者:PETER LAI ,是 Diode 的区块链工程师。在进入软件开发领域之前,他主要是在做工商管理相关工作。Peter Lai 也是一位活跃的开源贡献者。目前,他正在与 Diode 团队一起开发基于区块...

红薯
今天
10
0
CC攻击带来的危害我们该如何防御?

随着网络的发展带给我们很多的便利,但是同时也带给我们一些网站安全问题,网络攻击就是常见的网站安全问题。其中作为站长最常见的就是CC攻击,CC攻击是网络攻击方式的一种,是一种比较常见的...

云漫网络Ruan
今天
12
0
实验分析性专业硕士提纲撰写要点

为什么您需要研究论文的提纲? 首先当您进行研究时,您需要聚集许多信息和想法,研究论文提纲可以较好地组织你的想法, 了解您研究资料的流畅度和程度。确保你写作时不会错过任何重要资料以此...

论文辅导员
今天
8
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部