sql中出生日期是datetime类型,怎样算出年龄

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sql中出生日期是datetime类型,怎样算出年龄相关的知识,希望对你有一定的参考价值。

真实年龄(周岁):

select datediff(yyyy,出生日期列,getdate())

虚岁:

select datediff(yyyy,出生日期列,getdate())+1
参考技术A select datediff(YY,生日,getdate()) as 年龄 from 表
另外给你datediff的用法
DATEDIFF(datepart,startdate,enddate)
startdate 和 enddate 参数是合法的日期表达式。

datepart 参数可以是下列的值:

datepart 缩写
年 yy, yyyy
季度 qq, q
月 mm, m
年中的日 dy, y
日 dd, d
周 wk, ww
星期 dw, w
小时 hh
分钟 mi, n
秒 ss, s
毫秒 ms
微妙 mcs
纳秒 ns
参考技术B select year(getdate())-year(出生日期) as年龄from 表名 参考技术C

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

参考技术A 第一种:\\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)

以上是关于sql中出生日期是datetime类型,怎样算出年龄的主要内容,如果未能解决你的问题,请参考以下文章

如何用SQL语句把出生日期计算年龄,比如是1984-2-16怎么算出年龄啊

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

SQL 中身份证编码与出生日期验证

怎样在excel中算平均年龄

如何用身份证号码算出年龄???

数据库出生日期用啥类型比较好?datetime 或 varchar