SQL根据出生日期精确计算年龄、获取日期中的年份、月份 |
您所在的位置:网站首页 › 请用year函数计算每个人的工龄 › SQL根据出生日期精确计算年龄、获取日期中的年份、月份 |
第一种: 一张人员信息表里有一人生日(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' getdate()= '2007-7-7' 算出结果为:6
在Oracle中,要获得日期中的年份,例如把sysdate中的年份取出来。 一种常用的方法是:to_number(to_char(sysdate,'yyyy')) 还有一种更好的方法,那就是使用oracle提供的Extract函数,使用方法是: extract(year from sysdate) ,此方法获得的结果是数值型的 ,这种方法省掉了类型转换,更加简洁。 相应的,要取得月份或日,可以用extract (month from sysdate) 和extract (day from sysdate) |
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |