精确计算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版本为我们提供了改进的技术来解决这些复杂性。
计算整数年龄的最佳方法:
此方法简单直接,但精度可能略低于小数方法。
<code class="language-sql">SELECT (YEAR(GETDATE()) - YEAR(DOB)) - CASE WHEN MONTH(GETDATE()) < MONTH(DOB) OR (MONTH(GETDATE()) = MONTH(DOB) AND DAY(GETDATE()) < DAY(DOB)) THEN 1 ELSE 0 END AS AgeIntYears FROM YourTable;</code>
计算小数年龄的最佳方法:
此方法使用DATEDIFF
函数和CASE
语句精确计算年龄,并考虑生日在当年是否已过。
<code class="language-sql">SELECT DATEDIFF(year, DOB, GETDATE()) - CASE WHEN MONTH(GETDATE()) < MONTH(DOB) OR (MONTH(GETDATE()) = MONTH(DOB) AND DAY(GETDATE()) < DAY(DOB)) THEN 1 ELSE 0 END AS AgeYearsDecimal FROM YourTable;</code>
请注意,以上代码假设DOB
列已转换为DATE
类型。 如果DOB
仍然是nvarchar(25)
类型,您需要在查询中添加类型转换,例如:CONVERT(DATE, DOB, 120)
。 选择合适的转换样式取决于您的DOB
数据的具体格式。 例如,CONVERT(DATE, DOB, 120)
适用于'yyyy-mm-dd hh:mi:ss'格式。 您可能需要调整此部分以适应您的数据格式。 最终的查询应类似于:
<code class="language-sql">SELECT DATEDIFF(year, CONVERT(DATE, DOB, 120), GETDATE()) - CASE WHEN MONTH(GETDATE()) < MONTH(CONVERT(DATE, DOB, 120)) OR (MONTH(GETDATE()) = MONTH(CONVERT(DATE, DOB, 120)) AND DAY(GETDATE()) < DAY(CONVERT(DATE, DOB, 120))) THEN 1 ELSE 0 END AS AgeYearsDecimal FROM YourTable;</code>
替换YourTable
为您的表名。 选择整数或小数方法取决于您的精度需求。 小数方法更精确,但整数方法更简洁。
以上是如何在 SQL Server 中准确计算从出生日期算起的年龄?的详细内容。更多信息请关注PHP中文网其他相关文章!