首页 > 数据库 > mysql教程 > 如何在 SQL Server 中准确计算从出生日期算起的年龄?

如何在 SQL Server 中准确计算从出生日期算起的年龄?

DDD
发布: 2025-01-22 13:41:10
原创
101 人浏览过

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版本为我们提供了改进的技术来解决这些复杂性。

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

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

<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中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板