有关mysql实现oracle分析函数功能的方法(mysql分组然后组内排序)
目前公司erp开发有一个脚本需求:对于收款合同审批单和收款合同(n:1),需要获取收款审批单中最新的一条审批记录来更新其对应的收款合同的相关信息。
难点主要在对相同类别的属性进行分组然后组内排序(分组排序加序号),这类问题大致的思路,对于同类别的进行分组,组内排序标号来获取最新一条的数据,有点类似Oracle的分析函数功能。
由于mysql没有实现分析函数功能,在查询网上许多帖子也都是互相复制的也没有说清楚,根据我所遇到等坑,在此记录,分享给大家,希望能对大家有所帮助。
审批单的表结构大致如下:(红色方框内的是外键,有重复记录的id)
实现的具体SQL如下:
select * from (
select tmp.*,
/*看当前的parentId是否与你赋值的相等 如果相等的话说明就是同类分组中的数据rownum+1否则是新的类别的数据rownum=1*/
@rownum:=if(@parentId=tmp.parent_id,@rownum+1,1) rownum,
@parentId:= tmp.parent_id parentId /*设置 @parentId等于上一个 parent_id */
from
(
select
id,
parent_id,
apply_user,
first_party_linkman,
first_party_phone,
create_time
from pm_contract_approve
where parent_id is not null
and parent_id!=''
/*注意这个地方的排序优先级最高的一定要是parent_id ,即以重复记录列的排序优先级最高,否则会出现列序号错误问题*/
ORDER BY parent_id desc,create_time DESC
)tmp,
(SELECT @rownum:= 0,@parentId:=null)a /*定义参数行序号rownum和变量parentId(该变量辅助必须是重复记录列的值)*/
)T
最终结果如下: