oracle的使用case函数列的别名问题

本文详细解析了在SQL中使用Case函数的正确方法,特别是针对带有别名的Case表达式的语法规范,避免因错误语法导致的运行时错误。

当case函数列不使用别名的时候,末尾的end case 中case可以加可以不加, 但是当这一列要有别名的时候,就不能加case.

例如

SELECT 
ORDER_ID,
CASE  WHEN RPTERM = '1' and to_date(ACTUAL_PAYDATE,'yyyy-mm-dd') - to_date(PAY_DATE,'yyyy-mm-dd') > 0 THEN to_date(ACTUAL_PAYDATE,'yyyy-mm-dd') - to_date(PAY_DATE,'yyyy-mm-dd')
ELSE null END CASE OverdueDays1 
from 
CGI_REPAY_PLAN

会报错,需要去掉Case

SELECT 
ORDER_ID,
CASE  WHEN RPTERM = '1' and to_date(ACTUAL_PAYDATE,'yyyy-mm-dd') - to_date(PAY_DATE,'yyyy-mm-dd') > 0 THEN to_date(ACTUAL_PAYDATE,'yyyy-mm-dd') - to_date(PAY_DATE,'yyyy-mm-dd')
ELSE null END OverdueDays1 
from 
CGI_REPAY_PLAN

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值