Mysql 分组聚合实现 over partition by 功能
2015-10-10 13:57
716 查看
mysql中没有类似oracle和postgreSQL的 OVER(PARTITION BY)功能. 那么如何在MYSQL中搞定分组聚合的查询呢
先说结论: 利用 group_concat + substr等函数处理
例如: 订单表一张, 只保留关键字段
业务: 查找每个用户的最近一笔消费金额
单纯使用group by user_id, 只能按user_id 将money进行聚合, 是无法将最近一单的金额筛选出来的, 只能满足这些需求, 例如: 每个用户的总消费金额 sum(money), 最大消费金额 max(money), 消费次数count(1) 等
但是我们有一个group_concat可以用, 思路如下:
1. 查找出符合条件的记录, 按user_id asc, create_time desc 排序;
2. 将(1)中记录按user_id分组, group_concat(money);
3. 这时, 如果用户有多个消费记录, 就会按照时间顺序排列好, 再利用 subString_index 函数进行切分即可
完整SQL:
利用这个方案, 以下类似业务需求都可以这么做, 如:
1. 查找每个用户过去10个的登陆IP
2. 查找每个班级中总分最高的两个人
先说结论: 利用 group_concat + substr等函数处理
例如: 订单表一张, 只保留关键字段
id | user_id | money | create_time |
1 | 1 | 50 | 1420520000 |
2 | 1 | 100 | 1420520010 |
3 | 2 | 100 | 1420520020 |
4 | 2 | 200 | 1420520030 |
单纯使用group by user_id, 只能按user_id 将money进行聚合, 是无法将最近一单的金额筛选出来的, 只能满足这些需求, 例如: 每个用户的总消费金额 sum(money), 最大消费金额 max(money), 消费次数count(1) 等
但是我们有一个group_concat可以用, 思路如下:
1. 查找出符合条件的记录, 按user_id asc, create_time desc 排序;
select ord.user_id, ord.money, ord.create_time from orders ord where ord.user_id > 0 and create_time > 0 order by user_id asc , create_time desc
user_id | money | create_time |
1 | 100 | 1420520010 |
1 | 50 | 1420520000 |
2 | 200 | 1420520030 |
2 | 100 | 1420520020 |
select t.user_id, group_concat( t.money ) moneys from (select ord.user_id, ord.money, ord.create_time from orders ord where ord.user_id > 0 and create_time > 0 order by user_id asc , create_time desc) t group by user_id
user_id | moneys |
1 | 100,50 |
2 | 200,100 |
完整SQL:
select t.user_id, substring_index(group_concat( t.money ),',',1) lastest_money from (select ord.user_id, ord.money, ord.create_time from orders ord where ord.user_id > 0 and create_time > 0 order by user_id asc , create_time desc) t group by user_id ;
user_id | moneys |
1 | 100 |
2 | 200 |
1. 查找每个用户过去10个的登陆IP
2. 查找每个班级中总分最高的两个人
相关文章推荐
- MYSQL 源代码编绎脚本
- mysql删除一条数据后id不在连续的解决方法
- MySQL中char、varchar和text的区别
- mysql插入远程用户命令
- MYSQL 源代码学习
- MySql绿色版配置及使用详解
- mysql中date_add与date_sub函数使用详解
- mysql 的load data infile要使用
- Tracing mysqld Using DTrace
- mysql看视频笔记
- mysql和sqlserver的区别
- 动软代码生成器v2.78Mysql备注生成完美修复dll
- 不同场景下 MySQL 的迁移方案
- mysql免安装方法
- MySQL删除重复记录只保留一条
- MySQL自建函数之得到两个日期间连续的日期
- .Net识别不了MySql.DateTime类型解决
- MYSQL explain详解
- MySQL中group_concat函数深入理解
- MySQL中group_concat函数深入理解