避免利用Oracle规避正负数矛盾(oracle正负数)
的解决方案
Oracle这种数据库,即使有正确的数据,也可能存在正负数矛盾的情况。比如,有一个表t1,有科目、金额两个字段。你尝试查询某科目在某一段时间内的总金额,得到的结果是正负数之和为零,即rownum1上金额为10,rownum2上金额-10.这样的情况就是正负数的矛盾,它主要是由于Oracle的优化器的特点所致。
避免Oracle中正负数矛盾的关键是找到有效的解决方案,来保证查询的结果准确可靠。一种常用的方法是在原始的SQL上加入Order by进行排序,确保返回的结果中正负数相互抵消,比如:
select t1_name,sum(t1_amount) as t1_amount
from table1 t1
where t1_date between ’20xx-01-01′ and ’20xx-06-30′
group by t1_name
order by t1_amount desc;
运行上面的语句,将返回正确的加和结果,因为Order by语句保证了最先出现的正金额在最后被减掉。另一种可用的解决方案是采用双重SQL语句,分别查询入账金额和出账金额:
select sum(amount_in)
from table1 t1
where t1_type=’in’
and t1_date between ’20xx-01-01′ and ’20xx-06-30′;
select sum(amount_out)
from table1 t1
where t1_type=’out’
and t1_date between ’20xx-01-01′ and ’20xx-06-30′;
通过执行这两个语句,就可以获得入账金额和出账金额的单独结果,再将它们相加就可以得到总的净金额。这种方法能很好的避免正负数的矛盾,因两个不同的SQL语句取决于不同的条件,会得到完全正确的结果。
为了保证优化器的性能,有时我们还需要增加hint,尽可能避免一些性能低下的SQL语句。
总之,要避免利用Oracle规避正负数矛盾,除了增加Order by或者双重SQL语句外,还可以增加hint的技巧来优化SQL语句的性能。