mysql中GROUP BY结合GROUP_CONCAT的使用_MySQL

php中文网
发布: 2016-06-01 13:35:42
原创
1243人浏览过

bitsCN.com

mysql中group by结合group_concat的使用

 

我们知道,group by可以将sql查询结果按照group by后面列进行分类显示。比如:

Sql代码

select columnA,columnB from table group by columnA,columnB  

 则查询结果将按照columnA和columnB分类显示。没有显示在group by中的列不能直接作为返回列放在sql语句中,比如如下sql就是不正确的

 

Sql代码      

select columnA,columnC from table group by columnA   

 由于columnC不在group by的范围之类,所以这样写是不对的,所幸的是,group by支持一些sql 函数的使用,比如SUM,AVG,COUNT等等。这些都比较常用,今天我要记录下的是这个不常用的GROUP_CONCAT。  www.bitsCN.com  

 

有一个需求,需要用到group by 才能实现,可是,我同是还需要返回某列的所有结果,(注意,不是做avg,sum等操作,我要枚举这列的所有结果),那么就可以用到GROUP_CONCAT。

 

举个例子:

 

我有一张数据库表结构如下:

 

列名 含义

year 年份

month 月份

volumn 期数

该表存储了某杂志的年份,月份和期数。如果需求对该表内容作如下显示:

 

2010年12月 第1期  第2期  第3期 第4期

2010年11月 第1期  第2期  第3期 第4期  第5期

2010年10月 第1期  第2期  第3期 第4期

2010年9月 第1期  第2期  第3期 第4期  第5期

2010年8月 第1期  第2期  第3期 第4期 

 

 

sql该怎么写呢?按照年份和月份做group by?然后按照年份和月份做倒叙排列?

 

Sql代码      

select year,month from magazine group by year,month order by year desc,month desc  

 那具体的期数信息就丢了?能不能做group by的时候,还能返回在某个年份year和月份month分组下的所有期数volumn信息?(某个年份+月份下的期数信息是不固定的,只能通过数据库查询才能获得)

乐活途购物分享社区
乐活途购物分享社区

beta v1.1版本为第一个版本,简单的整合了基础功能,各位站长拿到程序后,不要纠结后台的功能简单,后续将不断更新扩展。在beta v1.1版本使用过程中遇到什么问题,请登录 www.loftto.com 进行反馈! 安装说明######重要提醒:程序不支持二级目录安装,请使用一级目录或二级目录绑定!#第一步,确定你的服务器支持PHP+mysql。#第二步,确定你的服务器开启了gd库。#第三步,

乐活途购物分享社区 0
查看详情 乐活途购物分享社区

 

该是GROUP_CONCAT上阵的时候了。

 

Sql代码      

select year,month GROUP_CONCAT(volumn) from magazine group by year,month order by year desc, month desc  

 这样,查询的返回结果类似于:

 

year month GROUP_CONCAT(volumn)

2010 12 1,2,3,4

2010 11 1,2,3,4,5

 

 

不错吧?

 

还有点问题需要补充下,就是作为GROUP_CONCAT函数参数的字段,如过返回值为string,则上面的sql语句已经没有问题,但是如果是number,则返回的GROUP_CONCAT(volumn)值为BLOB类型(其实上面例子返回的就是一个blob类型,我只是为了演示的方便),需要做一下转化。

 

Sql代码      

select year,month GROUP_CONCAT(conv( oct( volumn ) , 8, 10 )) from magazine group by year,month order by year desc, month desc  

 上面的sql对volumn做了一个从8进制到10进制的转换,这样返回的就是一个字符串了。

 

mysql默认会以‘,’来分隔多的值,如果想用其他的分隔符来分隔返回结果,比如期望返回值是这样的:1|2|3|4

 

这可以用SEPARATOR来搞定。

 

Sql代码      

select year,month GROUP_CONCAT(conv( oct( volumn ) , 8, 10 ) SEPARATOR '|') from magazine group by year,month order by year desc, month desc   

更牛的是,你甚至可以对返回的volumn进行排序!!

 

Sql代码      

select year,month GROUP_CONCAT(conv( oct( volumn ) , 8, 10 ) order by volumn desc SEPARATOR '|') from magazine group by year,month order by year desc, month desc  

 

 

这个不常用的东东,还是比较好用的。

bitsCN.com
相关标签:
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号