相关文章推荐
千杯不醉的黑框眼镜  ·  NLP ...·  10 月前    · 
气势凌人的西装  ·  Android ...·  10 月前    · 

SQL年龄计算的两种方法实例

作者:美人她爹

在做sql内容的时候遇到了问题,不知道如何根据出生日期计算年龄,所以整理出了计算年龄的两种方法,下面这篇文章主要给大家介绍了关于SQL年龄计算的两种方法,需要的朋友可以参考下

第一种方法:

用DATEDIFF函数, DATEDIFF(YEAR,beginDate,endDate)

测试语句:

DECLARE @birthdayDate DATE
DECLARE @endDate DATE
DECLARE @age INT
SET @birthdayDate ='2003-08-08'
SET @endDate = '2008-07-08'
SET @age = DATEDIFF(YEAR,@birthdayDate,@endDate)
SELECT @age AS 年龄

执行结果:

这种方法计算出的年龄,是个大概年龄,是“年”意义下的年龄,就是普罗大众对年龄的理解下的年龄。

如果按“月”、“日”去计算,上述例子中的年龄其实是不足5岁的。

所以,当我们写的程序对年龄的计算的精度要求比较高时,

比如社保待遇的享受起始时间、退休金发放起始时间的计算,需要对年龄的精确计算;

政治生活中,干部的提拔、退职,也都涉及到年龄的精确计算;

民事刑事案件中当事人年龄的计算,年龄的大小直接涉及到量刑的轻重,所以也需要对年龄进行精确计算。

第二种方法:

FLOOR(DATEDIFF(DAY,@birthdayDate,@endDate)/365.25)

FLOOR函数:返回小于或等于指定数值表达式的最大整数。又称,向下取整函数。

(Returns the largest integer less than or equal to the specified numeric expression.)

PS:numberic expression,数值表达式 ,arithmeric expression,算术表达式。

FLOOR(4)=4,

FLOOR(4.2)=4,

FLOOR(4.5)=4,

FLOOR(4.9)=4.

测试语句:

DECLARE @birthdayDate DATE
DECLARE @endDate DATE
DECLARE @age FLOAT
SET @birthdayDate ='2003-08-08'
SET @endDate = '2008-07-08'
SET @age = FLOOR(DATEDIFF(DAY,@birthdayDate,@endDate)/365.25)
SELECT @age AS 年龄

执行结果:

算法释义:

因为4年有一闰年会多1天,多除以0.25,相当于把这一天平均摊到这4年,保证每4年的误差归零。

这个算法其实也有小小的误差,除非出生不满一岁就碰到闰月,先有一天再来递减,会完全正确,不然的话在遇到闰年前会差一天,遇到闰年后变准确,但是当这个闰年补完4年差额在遇到下一个闰年之前又会差一天。也就是生日当天程序会显示没满周岁。

我们测试一下,比如2000、2004、2008年是闰年,但是2001、2002、2003、2005、2006、2007年都不是闰年。

假定李某在2001-02-08出生,我们用2002、2003、2004年生日当天去计算年龄时,都会发生误差。

因为2004年是闰年,用2005年生日当天去计算年龄就正确,过了2005年(2005-2001=4),我们用2006、2007、2008年生日当天去计算年龄,也会发生误差。

如果李某在2001-03-08(只要过了2月的一个日期就行)出生,

我们用2002、2003年生日当天去计算年龄时,会发生误差。

但是用2004、2005年生日当天去计算年龄就正确,过了2005年(2005-2001=4),我们用2006、2007年生日当天去计算年龄,也会发生误差。

用2008年生日当天去计算年龄,就没有误差。

请读者自行验证。

到此这篇关于SQL年龄计算的文章就介绍到这了,更多相关SQL年龄计算内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
  • SQL语句如何实现超简单的多表查询
    SQL语句如何实现超简单的多表查询
    2022-05-05
  • sql server查询语句阻塞优化性能
    sql server查询语句阻塞优化性能
    2022-04-04
  • sql语句中union的用法与踩坑记录
    sql语句中union的用法与踩坑记录
    2022-03-03
  • SQL年龄计算的两种方法实例
    SQL年龄计算的两种方法实例
    2022-03-03
  • SQL Server序列SEQUENCE用法介绍
    SQL Server序列SEQUENCE用法介绍
    2022-03-03
  • SQL解决未能删除约束问题drop constraint
    SQL解决未能删除约束问题drop constraint
    2022-03-03
  • msSQL中having的用处详解
    msSQL中having的用处详解
    2022-03-03
  • 美国设下计谋,用娘炮文化重塑日本,已影响至中国
    美国设下计谋,用娘炮文化重塑日本,已影响至中国
    2021-11-19
  • 时空伴随者是什么意思?时空伴随者介绍
    时空伴随者是什么意思?时空伴随者介绍
    2021-11-09
  • 工信部称网盘企业免费用户最低速率应满足基本下载需求,天翼云盘回应:坚决支持,始终
    工信部称网盘企业免费用户最低速率应满足基本下载需求,天翼云盘回应:坚决支持,始终
    2021-11-05
  • 2022年放假安排出炉:五一连休5天 2022年所有节日一览表
    2022年放假安排出炉:五一连休5天 2022年所有节日一览表
    2021-10-26
  • 电脑版 - 返回首页

    2006-2023 脚本之家 JB51.Net , All Rights Reserved.
    苏ICP备14036222号