Oracle nvl ,MONTHS_BETWEEN 函数

SELECT
ROW_NUMBER () OVER (ORDER BY st.create_date DESC) rowno,
TO_CHAR (
st.create_date,
'yyyy-MM-dd'
) trade_date,
st.trade_no,
st.total_amount,
st.actual_amount,
st.insurance_pay,
NVL (st.person_count_pay, 0) person_count_pay,
(
CASE
WHEN st.anam_no IS NOT NULL THEN
--查询病案信息
(
SELECT
'门' || mr.anam_no || ' ' || mr. NAME || ' ' || mr.sex_name || ' ' || FLOOR (
MONTHS_BETWEEN (SYSDATE, mr.birthday) / 12
) c
FROM
t_medical_record mr
WHERE
mr.anam_no = st.anam_no
AND ROWNUM = 1
)
ELSE
--查询手册信息
(
SELECT
'手' || pi.pati_no || ' ' || pi.patient_name || ' ' || pi.gender_name || ' ' || pi.age
FROM
t_patient_info pi
WHERE
pi.pati_no = st.pati_no
AND ROWNUM = 1
)
END
) AS patient_info,
inv.invoice_no,
tu.user_name toll_collector,
st.his_trade_no
FROM
t_settle st
INNER JOIN t_settle_invoice_relation sir ON sir.settle_id = st.settle_id
INNER JOIN t_invoice inv ON sir.invoice_id = inv.invoice_id
AND inv.status = '1'
LEFT JOIN his_db.t_user tu ON st.create_by = tu.user_id
WHERE
st.STATUS = '1'
AND st.pay_type = 'PH0024_02'
AND st.CREATE_DATE >= TO_DATE (
'2018-04-01 00:00:00',
'yyyy-MM-dd HH24:mi:ss'
)
AND st.CREATE_DATE <= TO_DATE (
'2018-04-09 00:00:00',
'yyyy-MM-dd HH24:mi:ss'
)
ORDER BY

st.create_date DESC;

NVL(E1, E2)的功能为:如果E1为NULL,则函数返回E2,否则返回E1本身。但此函数有一定局限,所以就有了NVL2函数。
拓展:NVL2函数:Oracle/PLSQL中的一个函数,Oracle在NVL函数的功能上扩展,提供了NVL2函数。 NVL2(E1, E2, E3)的功能为:如果E1为NULL,则函数返回E3,若E1不为null,则返回E2。
months_between函数返回两个日期之间的月份数。如果两个日期月份内天数相同,或者都是某个月的最后一天,返回一个整数,否则,返回数值带小数,以每天1/31月来计算月中剩余天数。
months_between(date1, date2),必须注意的是,date1与date2都为Date类型,不然会出现错误。须用to_date(‘’,'') 来转换为日期格式,才能参加计算。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值