”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 如何从SQL Server的出生日期开始准确计算年龄?

如何从SQL Server的出生日期开始准确计算年龄?

发布于2025-03-23
浏览:275

How to Accurately Calculate Age in Years from a Date of Birth in SQL Server?

精确计算SQL Server中出生日期的年龄

问题:

如何在SQL Server中将存储为nvarchar(25)的出生日期转换为日期,并随后计算其对应的年龄(以年为单位)?

示例数据:

ID Name DOB
1 John 1992-01-09 00:00:00
2 Sally 1959-05-20 00:00:00

预期输出:

ID Name AGE DOB
1 John 31 1992-01-09 00:00:00
2 Sally 64 1959-05-20 00:00:00

答案:精确计算年龄

最初提出的方法在考虑闰年和月份天数不规则性方面面临挑战。现代SQL Server版本为我们提供了改进的技术来解决这些复杂性。

计算整数年龄的最佳方法:

此方法简单直接,但精度可能略低于小数方法。

SELECT
    (YEAR(GETDATE()) - YEAR(DOB)) - CASE WHEN MONTH(GETDATE()) 

计算小数年龄的最佳方法:

此方法使用DATEDIFF函数和CASE语句精确计算年龄,并考虑生日在当年是否已过。

SELECT
    DATEDIFF(year, DOB, GETDATE()) - CASE WHEN MONTH(GETDATE()) 

请注意,以上代码假设DOB列已转换为DATE类型。 如果DOB仍然是nvarchar(25)类型,您需要在查询中添加类型转换,例如:CONVERT(DATE, DOB, 120)。 选择合适的转换样式取决于您的DOB数据的具体格式。 例如,CONVERT(DATE, DOB, 120)适用于'yyyy-mm-dd hh:mi:ss'格式。 您可能需要调整此部分以适应您的数据格式。 最终的查询应类似于:

SELECT
    DATEDIFF(year, CONVERT(DATE, DOB, 120), GETDATE()) - CASE WHEN MONTH(GETDATE()) 

替换YourTable为您的表名。 选择整数或小数方法取决于您的精度需求。 小数方法更精确,但整数方法更简洁。

最新教程 更多>

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3