sql通过日期判断年龄函数的示例代码

 更新时间:2021年07月15日 16:12:19   作者:kueizheng  
这篇文章主要介绍了sql通过日期判断年龄函数,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

定义函数:

CREATE FUNCTION [dbo].[GetAge]  
(  
@BirthDay nvarchar(20) --生日  
)  
RETURNS varchar(20)  
AS  
BEGIN  
if(@BirthDay is NUlL or @BirthDay='')
return '';
 -- Declare the return variable here  
 DECLARE @age varchar(20)  
 DECLARE @years int  
 DECLARE @months int  
 DECLARE @days int  
 -- Add the T-SQL statements to compute the return value here  
 set @age = ''  
  
 set @years = year(GETDATE()) - year(@birthday)  
 set @months = month(GETDATE()) - month(@birthday)  
 if day(@birthday)<=day(GETDATE())  
   set @days = day(GETDATE()) - day(@birthday)  
 else  
   begin  
     set @months = @months - 1  
     if MONTH(@birthday) in (1,3,5,7,8,10,12)  
       set @days = 31-day(@birthday)+day(GETDATE())  
     else if MONTH(@birthday) in (4,6,9,11)  
       set @days = 30-day(@birthday)+day(GETDATE())  
     else if MONTH(@birthday) = 2  
       if (year(@birthday)%4 = 0 and year(@birthday)%100 <> 0) or year(@birthday)%400 = 0  
         set @days = 29-day(@birthday)+day(GETDATE())  
       else  
         set @days = 28-day(@birthday)+day(GETDATE())  
   end  
 if @months < 0  
   begin  
     set @years = @years - 1  
     set @months = @months + 12  
   end  
 if @years = 0 and @months = 0  
 begin  
     return convert(varchar,@days+1) + '天'  
  end  
 if @years > 0  
   set @age = cast(@years as varchar(5)) + '岁'  
 if @years < 3 and @months > 0 and @years>-1  
 begin  
   set @age = @age + cast(@months as varchar(5)) + '月'  
 end  
 if @years<0  
 set @age=''  
 RETURN @age  
END

使用函数:

到此这篇关于sql通过日期判断年龄函数的示例代码的文章就介绍到这了,更多相关sql日期计算年龄内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • mybatis collection 多条件查询的实现方法

    mybatis collection 多条件查询的实现方法

    这篇文章主要介绍了mybatis collection 多条件查询的实现方法的相关资料,希望通过本文能帮助到大家,需要的朋友可以参考下
    2017-10-10
  • SQL Server STUFF函数的用法及应用场景

    SQL Server STUFF函数的用法及应用场景

    SQLServer中的STUFF函数用于删除指定位置的字符并插入新的字符,本文主要介绍了SQL Server STUFF函数的用法及应用场景,具有一定的参考价值,感兴趣的可以了解一下
    2025-03-03
  • SQL 研究 相似的数据类型

    SQL 研究 相似的数据类型

    数据类型在精度,范围上有较大的差别。选择合适的类型可以减少table和index的大小,进而减少IO的开销,提高效率。本文介绍基本的数值类型及其之间的细小差别。
    2009-07-07
  • MSSQL 检查所使用的语句是否符合标准

    MSSQL 检查所使用的语句是否符合标准

    标准SQL和T-SQL之间有很多区别——太多了,这里就不说了。还有,如果你在SQL Server上工作, 那么使用这些私有的扩展是有好处的。
    2009-11-11
  • SQL服务器无法启动的解决方法

    SQL服务器无法启动的解决方法

    这篇文章主要为大家详细介绍了SQL服务器无法启动的解决方法,以及SQLserverAgent无法启动的解决方法
    2017-03-03
  • SQLServer中RAISERROR的用法小结

    SQLServer中RAISERROR的用法小结

    RAISEERROR是一种用于生成错误消息并返回其错误号的机制,本文主要介绍了SQLServer中RAISERROR的用法小结,具有一定的参考价值,感兴趣的可以了解一下
    2024-06-06
  • sqlserver 2000中每个服务器角色的解释

    sqlserver 2000中每个服务器角色的解释

    sqlserver 2000中每个服务器角色的解释,方便大家以后对于数据库权限有所了解。
    2011-03-03
  • SQLSERVER中忽略索引提示

    SQLSERVER中忽略索引提示

    这篇文章主要介绍了SQLSERVER中如何忽略索引提示,需要的朋友可以参考下
    2014-11-11
  • sql 查询慢的原因分析

    sql 查询慢的原因分析

    sql 查询慢的48个原因分析。
    2009-07-07
  • SQL注入之sqlmap入门学习

    SQL注入之sqlmap入门学习

    本文主要介绍了SQL注入之sqlmap入门学习,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-05-05

最新评论