积分功能由原来的有效期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;
很明显2015年11月只有10分,2015年11月+12月积分有12分,扣除11分最少应该减少201511月和12月的数据,2016年1月的数据跟本次操作无关。
sql逻辑如下:
select t.d, --手机号
t.a, --月份
t.b, -- 当月积分
sum(t.b) over(partition by t.d order by t.a) sum_value, --当月积分+之前月积分
(sum(t.c) over(partition by t.d) + 11) exchange_value --已兑换积分+将要兑换积分
from tmp_table t
where t.d = '13800138000';
通过执行结果可以看到2015年12月为临界点,12月之前的积分都被兑换完毕,12月一部分积分被兑换,12月之后的积分本次兑换不被消耗。
通过sql语句反映上面的结了如下:
select d,
min(sum_value - exchange_value) over(partition by a) mark_value,
min(a) over(partition by d) mark_month,
row_number() over(partition by d order by d) cn
from (select t.d,
t.a,
t.b,
sum(t.b) over(partition by t.d order by t.a) sum_value,
(sum(t.c) over(partition by t.d) + 11) exchange_value
from tmp_table t
where t.d = '13800138000')
where (sum_value - exchange_value) >= 0;
获取第一条数据为基准,12月份之前的积分全部兑换,12月份积分兑换1分,12月之后的积分数据不处理。
merge into tmp_table m
using (select d, mark_value, mark_month
from (select d,
min(sum_value - exchange_value) over(partition by a) mark_value,
min(a) over(partition by d) mark_month,
row_number() over(partition by d order by d) cn
from (select t.d,
t.a,
t.b,
sum(t.b) over(partition by t.d order by t.a) sum_value,
(sum(t.c) over(partition by t.d) + 11) exchange_value
from tmp_table t
where t.d = '13800138000')
where (sum_value - exchange_value) >= 0)
where cn = 1) t2
on (m.d = t2.d)
when matched then
update
set m.c =
(case
when m.a < t2.mark_month then
m.b
when m.a > t2.mark_month then
0
else
m.b - t2.mark_value
end);
执行后的结果如下:
兑换处理完成,撤销同理。
相关推荐
Oracle 11g SQL和PL SQL从入门到精通 pdf格式电子书 下载(一) http://download.csdn.net/source/3268267 Oracle 11g SQL和PL SQL从入门到精通 pdf格式电子书 下载(二) ...
第一部分 sql和pl/sql相关工具 第1章 在windows 平台上安装oracle database 11g 第2章 配置网络服务名 第3章 使用sql database 第4章 使用sql*plus 第二部分 sql 第5章 sql和pl/sql综述 第6章 简单查询 ...
oracle SQL查询工具oracle SQL查询工具oracle SQL查询工具oracle SQL查询工具oracle SQL查询工具oracle SQL查询工具oracle SQL查询工具oracle SQL查询工具oracle SQL查询工具oracle SQL查询工具oracle SQL查询工具...
Oracle数据库是全球领先的企业级...由于是关于Oracle高性能SQL引擎的深入剖析,这本资料是数据库开发者和管理员难得的参考资料,尤其对于处理复杂业务逻辑和海量数据的场景下,掌握这些优化和调优技巧显得尤为重要。
Oracle和SqlServer语法区别 Oracle和SqlServer是两种流行的关系型数据库管理系统,它们之间存在着一些语法区别。了解这些区别对于开发者来说非常重要,因为它可以帮助他们更好地迁移到新的数据库管理系统。下面将...
Oracle的SQL监视工具SQLTracker是一款强大的性能分析工具,专为数据库管理员和开发人员设计,用于诊断和优化SQL查询性能。这款工具在Oracle数据库环境中扮演着重要角色,它可以帮助用户实时监控SQL语句的执行情况,...
市场上存在许多这样的工具,如SSMA(SQL Server Migration Assistant) for Oracle,这是一个官方提供的迁移工具,能自动分析SQL Server的架构,并生成适合Oracle的DDL(Data Definition Language)和DML(Data ...
SqlDbx是一款轻量级的数据库管理工具,特别适合于SQL查询和数据库开发。它以其直观的用户界面和对多种数据库系统的支持而受到青睐,包括Oracle。本篇将详细介绍如何使用SqlDbx连接到Oracle数据库,以及涉及的相关...
首先,需要打开迁移工具,然后登录Oracle数据库和SQL Server数据库。接着,需要选择要迁移的数据库,展开数据库,找到要迁移的表,然后选择 Convert Schema(转换模式)。等待完成后,SQL Server的区域会出现一个新...
Oracle PL/SQL是一种强大的编程语言,它结合了SQL的数据库操作能力和PL/SQL的结构化编程特性,使得数据库开发者能够创建复杂的应用程序和数据库逻辑。在"Oracle PL/SQL实例精解 数据库建立代码"中,我们将深入探讨...
在数据库管理领域,Oracle SQL和MySQL SQL是两种广泛使用的SQL方言,它们在语法和功能上存在一定的差异。当需要将一个基于Oracle SQL的应用程序迁移到MySQL环境时,就需要进行SQL语句的转换工作。本项目提供了一个...
ORACLE PL/SQL是从入门到精通的专业知识,涵盖了数据库开发与管理的多个方面,包括...这本书籍将为读者提供一个全面、系统的学习路径,帮助数据库管理员、开发人员深入理解并掌握ORACLE PL/SQL的强大功能和应用技巧。
- 下载并安装 Oracle SQL Developer,这是一个免费的图形化工具,用于管理和开发 Oracle 数据库。 - 安装过程中可以选择所需的组件,例如支持的数据库类型等。 2. **连接到 Oracle 数据库:** - 打开 SQL ...
简单描述Oracle v$sqlarea, v$sql, v$sqltext视图说明
Oracle与SQLServer的SQL语法差异,用简单易懂的语言和实例对Oracle和Sql Server语法之间的差异进行了对比分析,更加适用于入门的人
Oracle SQL 是一种强大的数据库查询和编程语言,广泛用于管理和操作Oracle数据库系统。11g第二版(11G2)是Oracle的一个重要版本,提供了许多增强功能和优化。本官方文档集包括四份重要的参考资料,涵盖了Oracle SQL...
Oracle SQL是数据库管理员和开发人员用来与Oracle数据库交互的语言,它是SQL标准的扩展,提供了许多特有的功能和优化。本资源“Oracle Sql基础(beginning oracle sql中文版)”旨在为初学者提供一个全面的Oracle ...
Oracle 数据库到 SqlServer 的数据迁移是一项复杂的任务,需要经过多个步骤来完成。本文将详细介绍如何将 Oracle 数据库导入到 SqlServer 中。 Step 1-6: 数据源设置 首先,在要导入的数据库上右键,点击“任务”...
本书是专门为Oracle应用开发人员提供的SQL和PL/SQL编程指南。通过学习本书,读者不仅可以掌握Oracle常用工具Oracle Universal Installer、Net Comfiguration Assistant、SQL Developer、SQL*Plus的作用及使用方法,...