ORACLE开发注意事项

1、代码自测应严格

2、若字段col1由源表若干字段依据公式计算而来,col2由col1计算而来,则计算col1的结果不应先保留小数位,否则会造成col2的计算有误差,应只在最后的结果中保留小数位。

3、取源表增量部分数据时,要取全,把所有受影响的、参与计算的数据都取出来。

3、关联提取,主键来自一张表TABLE1时,从附表TABLE2取出来的字段col2处理方式有两种(以录入转中心为例):

WITH TMP AS

(

SELECT ID,COL1,COL2

FROM TABLE1 A

WHERE INPUTSTATE=1 AND UPDATETIME>V_NOWTIME AND UPDATETIME<=V_MAXTIME

OR EXISTS ( SELECT ID,COL3

                      FROM TABLE2

                      WHERE INPUTSTATE=1 AND UPDATETIME>V_NOWTIME1 AND UPDATETIME<=V_MAXTIME1

                     )

)

SELECT

A.ID,A.COL1,A.COL2,B.COL3

FROM TMP A

LEFT JOIN TABLE2 B

ON A.ID=B.ID AND B.INPUTSTATE=1 AND B.UPDATESTATE<=1 ;

 

 

 

WITH TMP AS

(

SELECT ID,COL1,COL2

FROM TABLE1 A

WHERE INPUTSTATE=1 AND UPDATETIME>V_NOWTIME AND UPDATETIME<=V_MAXTIME

OR EXISTS ( SELECT ID,COL3

                      FROM TABLE2

                      WHERE INPUTSTATE=1 AND UPDATETIME>V_NOWTIME1 AND UPDATETIME<=V_MAXTIME1

                     )

)

SELECT

A.ID,A.COL1,A.COL2,CASE WHEN B.UPDATESTATE<=1 THEN B.COL3 ELSE NULL END AS COL3

FROM TMP A

LEFT JOIN TABLE2 B

ON A.ID=B.ID AND B.INPUTSTATE=1

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值