mysql之group_concat函数
mysql之group_concat函数
在介绍GROUP_CONCAT之前,我们先来看看concat()函数和concat_ws()函数。
先准备一个测试数据库:
mysql> select * from scores;
+----+----------+-------+
| id | name | score |
+----+----------+-------+
| 1 | zhangsan | 100 |
| 2 | lisi | 90 |
| 3 | wangwu | 99 |
| 4 | zhangsan | 92 |
| 5 | zhangsan | 88 |
| 6 | lisi | 89 |
+----+----------+-------+
6 rows in set
concat()函数
concat()函数的功能是将多个字符连接成一个字符串。
语法: concat(str1, str2,...)
返回结果为连接参数产生的字符串,如果有任何一个参数为null,则返回值为null。
mysql> select *,concat(name,score) from scores;
+----+----------+-------+--------------------+
| id | name | score | concat(name,score) |
+----+----------+-------+--------------------+
| 1 | zhangsan | 100 | zhangsan100 |
| 2 | lisi | 90 | lisi90 |
| 3 | wangwu | 99 | wangwu99 |
| 4 | zhangsan | 92 | zhangsan92 |
| 5 | zhangsan | 88 | zhangsan88 |
| 6 | lisi | 89 | lisi89 |
+----+----------+-------+--------------------+
6 rows in set
-- 加分隔符 & 起别名
mysql> select *,concat(name,':',score) as info from scores;
+----+----------+-------+--------------+
| id | name | score | info |
+----+----------+-------+--------------+
| 1 | zhangsan | 100 | zhangsan:100 |
| 2 | lisi | 90 | lisi:90 |
| 3 | wangwu | 99 | wangwu:99 |
| 4 | zhangsan | 92 | zhangsan:92 |
| 5 | zhangsan | 88 | zhangsan:88 |
| 6 | lisi | 89 | lisi:89 |
+----+----------+-------+--------------+
6 rows in set
concat_ws()函数
concat()函数加分隔符比较麻烦,如果有10个字段连接起来,就得写9个分隔符,concat_ws()函数就是为了解决这个问题。concat_ws就是concat with separator。
语法: concat_ws(separator, str1, str2, ...)
第一个参数指定分隔符。需要注意的是分隔符不能为null,如果为null,则返回结果为null。
mysql> select *,concat_ws(':',name,score) as info from scores;
+----+----------+-------+--------------+
| id | name | score | info |
+----+----------+-------+--------------+
| 1 | zhangsan | 100 | zhangsan:100 |
| 2 | lisi | 90 | lisi:90 |
| 3 | wangwu | 99 | wangwu:99 |
| 4 | zhangsan | 92 | zhangsan:92 |
| 5 | zhangsan | 88 | zhangsan:88 |
| 6 | lisi | 89 | lisi:89 |
+----+----------+-------+--------------+
6 rows in set
group_concat函数
明白了concat()和concat_ws()函数,我们来看一下GROUP_CONCAT()函数。它的功能就是将group by产生的同一个分组中的值连接起来,返回一个字符串结果。如果单独使用,那么就将指定字段所有的值连接起来。
语法:
group_concat( [distinct] 要连接的字段 [order by 排序字段 asc/desc ][separator '分隔符'] )
说明:通过使用distinct可以排除重复值;如果希望对结果中的值进行排序,可以使用order by子句;separator是一个字符串值,缺省为一个逗号。
我们知道可以使用group by语句对结果进行分组处理:
mysql> select * from scores group by name;
+----+----------+-------+
| id | name | score |
+----+----------+-------+
| 2 | lisi | 90 |
| 3 | wangwu | 99 |
| 1 | zhangsan | 100 |
+----+----------+-------+
3 rows in set
但是我们只能看到zhangsan的第一个成绩,如果我想看到所有的成绩呢?
mysql> select *,group_concat(score) from scores group by name;
+----+----------+-------+---------------------+
| id | name | score | group_concat(score) |
+----+----------+-------+---------------------+
| 2 | lisi | 90 | 90,89 |
| 3 | wangwu | 99 | 99 |
| 1 | zhangsan | 100 | 100,92,88 |
+----+----------+-------+---------------------+
3 rows in set
-- 将分组结果按升序排序,并使用分隔符 :
mysql> select *,group_concat(score order by score separator ':') from scores group by name;
+----+----------+-------+--------------------------------------------------+
| id | name | score | group_concat(score order by score separator ':') |
+----+----------+-------+--------------------------------------------------+
| 2 | lisi | 90 | 89:90 |
| 3 | wangwu | 99 | 99 |
| 1 | zhangsan | 100 | 88:92:100 |
+----+----------+-------+--------------------------------------------------+
3 rows in set
-- 上面展示了以name分组后所有的score,现在多加展示一个id
mysql> select *,group_concat(concat_ws(':',id,score) order by id) from scores group by name;
+----+----------+-------+---------------------------------------------------+
| id | name | score | group_concat(concat_ws(':',id,score) order by id) |
+----+----------+-------+---------------------------------------------------+
| 2 | lisi | 90 | 2:90,6:89 |
| 3 | wangwu | 99 | 3:99 |
| 1 | zhangsan | 100 | 1:100,4:92,5:88 |
+----+----------+-------+---------------------------------------------------+
3 rows in set
-- 单独使用
mysql> select group_concat(score) from scores;
+---------------------+
| group_concat(score) |
+---------------------+
| 100,90,99,92,88,89 |
+---------------------+
1 row in set
参考:
mysql之group_concat函数的更多相关文章
- MySQL中group_concat函数-和group by配合使用
MySQL中group_concat函数 完整的语法如下: group_concat([DISTINCT] 要连接的字段 [Order BY ASC/DESC 排序字段] [Separator '分隔 ...
- MySQL中group_concat函数深入理解
本文通过实例介绍了MySQL中的group_concat函数的使用方法,比如select group_concat(name) . 一.MySQL中group_concat函数 完整的语法如下: gr ...
- MySQL中group_concat函数
本文通过实例介绍了MySQL中的group_concat函数的使用方法,比如select group_concat(name) .MySQL中group_concat函数完整的语法如下:group_c ...
- 【转】mysql的group_concat函数,默认最大长度是1024
mysql的group_concat函数,默认最大长度是1024 查询sql: show variables like 'group_concat_max_len'; 设置方式: 修改配置文件my.i ...
- MySQL中group_concat函数 --- 很有用的一个用来查询出所有group by 分组后所有 同组内的 内容
本文通过实例介绍了MySQL中的group_concat函数的使用方法,比如select group_concat(name) . MySQL中group_concat函数 完整的语法如下: grou ...
- mysql中group_concat函数用法
该函数返回带有来自一个组的连接的非NULL值的字符串结果.该函数是一个增强的Sybase SQL Anywhere支持的基本LIST()函数. 语法结构: GROUP_CONCAT([DISTINCT ...
- 利用MySQL 的GROUP_CONCAT函数实现聚合乘法
MySQL 聚合函数里面提供了加,平均数.最小,最大等,可是没有提供乘法,我们这里来利用MYSQL现有的GROUP_CONCAT函数实现聚合乘法. 先创建一张演示样例表: CREATE TABLE ` ...
- MYSQL中group_concat( )函数中参数的排序方法
使用mysql中的group_concat( )函数连接指定字段时,可以先对该字段进行排序. PS:是因为二刷mysql的51道题的第12题遇到的:查询和" 01 "号同学学习的课 ...
- 关于Mysql中GROUP_CONCAT函数返回值长度的坑
1.GROUP_CONCAT函数: 功能:将group by产生的同一个分组中的值连接起来,返回一个字符串结果. 语法:group_concat( [distinct] 要连接的字段 [order b ...
随机推荐
- centos mysql数据库问题:ERROR 1044 (42000): Access denied for user ''@'localhost' to database 'mysql'(转)
问题描述: 安装好数据库MySQL,进入mysql,设置号密码后,退出的时候,利用密码无法进入,直接回车后可进入,无法看到数据库mysql,use mysql返回错误:ERROR 1044 (4200 ...
- 关于将多个json对象添加到数组中的测试
如果用数组push添加不到数组中的,这个我也不知道是为什么?然后我选择了另一种发放就是从数组出发,逆向添加 最后的数组是这样的: data1=['公司1','公司2','公司3','公司4']; ar ...
- c#NPOI导出2007版本excel
2003和2007版本区别: HSSFWorkbook(2003) IWorkbook(2007版本) 写完之后会有个问题,导出会报错[流已关闭]. NPOI生产.xlsx文件件时,在使用book.W ...
- 二叉树BinaryTree构建测试(无序)
此测试仅用于二叉树基本的性质测试,不包含插入.删除测试(此类一般属于有序树基本操作). //二叉树树类 public class BinaryTree { public TreeNode root; ...
- ASE19团队项目 beta阶段 model组 scrum2 记录
本次会议于12月3日,19时整在微软北京西二号楼sky garden召开,持续10分钟. 与会人员:Jiyan He, Kun Yan, Lei Chai, Linfeng Qi, Xueqing W ...
- 阿里Java架构师打包 FatJar 方法小结
在函数计算(Aliyun FC)中发布一个 Java 函数,往往需要将函数打包成一个 all-in-one 的 zip 包或者 jar 包.Java 中这种打包 all-in-one 的技术常称之为 ...
- 当跨域时,js ajax 请求出现options请求
上面有文章说过http的options. 查了很久.试了很多版本的jQuery,下面这段代码在同事的机子上测试是没有问题的.正常 的请求, 一在我机子上面就会出现option,网上说先向服务器预检等. ...
- [Abp vNext微服务实践] - 文章目录
简介 ABP vNext是volosoft的新一代框架,ABP(vNext)完全使用.NET CORE和DDD(领域驱动)打造,目前GitHub已有6K+次提交,发布版本超过40次,Nuget包下载量 ...
- APP支付宝登录--PHP处理代码
1.首先需要参数: aucth_code udid re_id极光推送id 2.https://open.alipay.com/platform/keyManage.htm 配置公钥私钥 3.需要s ...
- java8的相关特性
1,为什么要介绍java8的相关特性? 因为现在的企业大部分已经从java7向java8开始迈进了,用java8的公司越来越多了,java8中的一些知识还是需要了解一些的; java8具有以下特点: ...