SQL语句如何根据出生日期计算年龄

 我来答
刺任芹O
2022-11-16 · TA获得超过6.2万个赞
知道顶级答主
回答量:38.7万
采纳率:99%
帮助的人:8827万
展开全部
第一种:\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)
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式