Oracle中根据生日求今年几岁

本文介绍了在SQL中使用不同方法来计算人员年龄的技巧,包括MONTHS_BETWEEN、datediff和FLOOR函数的应用,对比了它们在精确度上的差异。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

第一种方法

( Trunc(MONTHS_BETWEEN(sysdate,to_date(borthday, 'yyyy-MM')) / 12)

第二种方法

张人员信息表里有一人生日(Birthday)列,跟据这个列,算出该人员的年龄
datediff(year,birthday,getdate())
例:birthday = '2003-3-8'
getDate()= '2008-7-7'
结果为:5
这样结果是会返回该人员的大概年龄,但不精确.不会精确到月或日.
按照上面测试的日期,该人员的实际年龄应该还不满5岁。在需要精确年龄的时候,就会有错.
第二种:
FLOOR(datediff(DY,birthday,getdate())/365.25)
FLOOR函数:
FLOOR(expr) 返回小于或等于expr的最大整数.FLOOR(1.1)返回1,FLOOR(-1.1)返回-2,FLOOR(1)返回1
这样就可以精确算出,该人员当前实际年龄了.
测试:
birthday = '2000-7-8'

我自己写的第三种方法,不精确

select RYXX.CODE,RYXX.NAME_VALUE,RYXX.BORTHDAY,RYXX.PK_MONTH,RYXX.COMPANY,"TO_NUMBER"("TO_CHAR"(SYSDATE,'YYYY'))-TO_NUMBER(SUBSTR(BORTHDAY, 0, 4))from DIM_ORG_MAP ORG LEFT JOIN ETL_T_RYXX RYXX ON ORGNAME = RYXX.COMPANY

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值