31  
查询码: 00000324
SQL 根据日期精确计算年龄
来源:https://blog.csdn.net/esunshine1985/article/details/51494690
作者: 周杨 于 2019年05月30日 发布在分类 / 计算机应用 / 数据库 ,于 2019年05月30日 编辑
年龄 阅读 阅读数 读数 日期 生日 来自 计算 出生 根据


    第一种:

    一张人员信息表里有一人生日(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





     历史版本

    备注 修改日期 修改人
    CREAT 2019-05-30 18:16:01[当前版本] 系统管理员

    知识分享平台 -V 5.1.4 -大信谛威