一、问题
原来有三个充值订单,现在要退款450元,如何分配才能让本次退款涉及的充值订单数量最少?具体数据参考下图:
二、解决方案
Step 1:对可退金额进行降序排列,以便优先使用可退金额比较大的订单
Step 2:使用CTE公用表达式,实现类似for或while循环或游标的功能
三、脚本
create table #t ( 充值 int, 已退 int, 可退 int ) insert into #t(充值, 已退, 可退) values (200, 100, 100), (500, 200, 300), (300, 100, 200) /* 作者:zhang502219048 脚本来源:https://www.cnblogs.com/zhang502219048/p/14127208.html */ declare @i要退 int = 450; with cte1 as ( select *, row_number() over(order by 可退 desc) rn, 0 可发起退款, 0 待退 from #t ), cte2 as ( select rn, 充值, 已退, 可退, 可发起退款 = case when @i要退 > 可退 then 可退 else @i要退 end, 待退 = @i要退 - case when @i要退 > 可退 then 可退 else @i要退 end -- 待退 = 要退 - 可发起退款 from cte1 where rn = 1 union all select t2.rn, t2.充值, t2.已退, t2.可退, 可发起退款 = case when t1.待退 > t2.可退 then t2.可退 else t1.待退 end, 待退 = t1.待退 - case when t1.待退 > t2.可退 then t2.可退 else t1.待退 end from cte1 t2 inner join cte2 t1 on t1.rn = t2.rn - 1 -- t2是t1的下一条记录 --where t2.rn > 1 and t1.待退 > 0 ) select * from cte2 drop table #t
四、脚本运行结果
总结
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
白云城资源网 Copyright www.dyhadc.com
暂无“sql server把退款总金额拆分到尽量少的多个订单中详解”评论...
更新日志
2024年05月13日
2024年05月13日
- 发烧天碟《蓝调情歌》[WAV+CUE][663M]
- 群星.1991-瑞华金曲精绚精华汇聚2辑【瑞华】【WAV+CUE】
- 群星.2013-追梦敢不敢(2013快男合辑)【天娱】【FLAC分轨】
- 王若琳.2024-破烂酒店【SONY】【FLAC分轨】
- 没有一顿火锅解决不了的事
- 源生罪
- 哥斯拉大战金刚2:帝国崛起 Godzilla x Kong: The New Empire
- 千织角色攻略心得分享,千织角色武器攻略
- 《原神》茸茸城堡大喵险第四关攻略
- 《原神》4.5那芙万配队攻略 那芙万输出手法与出装推荐
- 任天堂社长:Switch继任者的宣布可能会影响公司销量
- 星穹铁道梦境护照16收集位置 那是一个最好的时代贴纸收集位置大全
- 金海心.-.[金海心].专辑.(APE+CUE)
- 破碎之地新手能力选择推荐 能力效果分析
- 《小猫咪大城市》Steam”好评如潮”!好评率高达95%