精确计算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