当前位置: 代码迷 >> SQL >> oracle一句sql搞定积分兑换跟撤销
  详细解决方案

oracle一句sql搞定积分兑换跟撤销

热度:120   发布时间:2016-05-05 09:43:10.0
oracle一句sql搞定积分兑换和撤销

积分功能由原来的有效期1个月升级到1年,相应的积分兑换功能就遇到了难题。
1、兑换需要从最接近有效期的积分月份里扣除
2、撤销兑换时的积分还原问题

开始设计是一个月一个月的查询然后扣除,这种查询多次数据库,效率很低。
最终发现了oracle数据库的sum(nid)?over(partition?by?v1?order?by?nid)函数。

效果如下:

一、先建表:
create table tmp_table(
A varchar(6), --月份
B number(10), --积分
C number(10), --兑换积分
D varchar(11) --手机号
);

二、插入测试数据:
insert into tmp_table(a,b,c,d)values('201511',10,0,'13800138000');
insert into tmp_table(a,b,c,d)values('201512',2,0,'13800138000');
insert into tmp_table(a,b,c,d)values('201601',50,0,'13800138000');


?三、兑换11分时查询该扣除的积分月份
select a,sum(b) over(partition by d order by a) sum_value from tmp_table;



?
?


?

  相关解决方案