• SQL如何根据存储的出生日期计算年龄
  • 无色无香 发表于 2016/2/16 15:41:00 | 分类标签: 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
  • 请您注意

    ·自觉遵守:爱国、守法、自律、真实、文明的原则

    ·尊重网上道德,遵守《全国人大常委会关于维护互联网安全的决定》及中华人民共和国其他各项有关法律法规

    ·严禁发表危害国家安全,破坏民族团结、国家宗教政策和社会稳定,含侮辱、诽谤、教唆、淫秽等内容的作品

    ·承担一切因您的行为而直接或间接导致的民事或刑事法律责任

    ·您在编程中国社区新闻评论发表的作品,本网站有权在网站内保留、转载、引用或者删除

    ·参与本评论即表明您已经阅读并接受上述条款

  • 感谢本文作者
  • 作者头像
  • 昵称:无色无香
  • 加入时间:2013/5/7 0:00:00
  • TA的签名
  • 这家伙很懒,虾米都没写
  • +进入TA的空间
  • 以下内容也很赞哦
分享按钮