SQL语句如何根据出生日期计算年龄
展开全部
第一种:\x0d\x0a一张人员信息表里有一人生日(Birthday)列,跟据这个列,算出该人员的年龄\x0d\x0adatediff(year,birthday,getdate())\x0d\x0a例:birthday = '2003-3-8'\x0d\x0agetDate()= '2008-7-7'\x0d\x0a结果为:5\x0d\x0a这样结果是会返回该人员的大概年龄,但不精确.不会精确到月或日.\x0d\x0a按照上面测试的日期,该人员的实际年龄应该还不满5岁。在需要精确年龄的时候,就会有错.\x0d\x0a第二种:\x0d\x0aFLOOR(datediff(DY,birthday,getdate())/365.25)\x0d\x0aFLOOR函数:\x0d\x0aFLOOR(expr) 返回小于或等于expr的最大整数.FLOOR(1.1)返回1,FLOOR(-1.1)返回-2,FLOOR(1)返回1\x0d\x0a这样就可以精确算出,该人员当前实际年龄了.\x0d\x0a测试:\x0d\x0abirthday = '2000-7-8'\x0d\x0agetdate()= '2007-7-7'\x0d\x0a算出结果为:6\x0d\x0a\x0d\x0a在Oracle中,要获得日期中的年份,例如把sysdate中的年份取出来。\x0d\x0a一种常用的方法是:to_number(to_char(sysdate,'yyyy'))\x0d\x0a还有一种更好的方法,那就是使用oracle提供的Extract函数,使用方法是:\x0d\x0aextract(year from sysdate) ,此方法获得的结果是数值型的 ,这种方法省掉了类型转换,更加简洁。\x0d\x0a相应的,要取得月份或日,可以用extract (month from sysdate) 和extract (day from sysdate)
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询