• 售前

  • 售后

热门帖子
入门百科

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

[复制链接]
poney 显示全部楼层 发表于 2021-8-14 14:32:44 |阅读模式 打印 上一主题 下一主题
定义函数:
  1. CREATE FUNCTION [dbo].[GetAge]  
  2. (  
  3. @BirthDay nvarchar(20) --生日  
  4. )  
  5. RETURNS varchar(20)  
  6. AS  
  7. BEGIN  
  8. if(@BirthDay is NUlL or @BirthDay='')
  9. return '';
  10. -- Declare the return variable here  
  11. DECLARE @age varchar(20)  
  12. DECLARE @years int  
  13. DECLARE @months int  
  14. DECLARE @days int  
  15. -- Add the T-SQL statements to compute the return value here  
  16. set @age = ''  
  17.   
  18. set @years = year(GETDATE()) - year(@birthday)  
  19. set @months = month(GETDATE()) - month(@birthday)  
  20. if day(@birthday)<=day(GETDATE())  
  21.    set @days = day(GETDATE()) - day(@birthday)  
  22. else  
  23.    begin  
  24.      set @months = @months - 1  
  25.      if MONTH(@birthday) in (1,3,5,7,8,10,12)  
  26.        set @days = 31-day(@birthday)+day(GETDATE())  
  27.      else if MONTH(@birthday) in (4,6,9,11)  
  28.        set @days = 30-day(@birthday)+day(GETDATE())  
  29.      else if MONTH(@birthday) = 2  
  30.        if (year(@birthday)%4 = 0 and year(@birthday)%100 <> 0) or year(@birthday)%400 = 0  
  31.          set @days = 29-day(@birthday)+day(GETDATE())  
  32.        else  
  33.          set @days = 28-day(@birthday)+day(GETDATE())  
  34.    end  
  35. if @months < 0  
  36.    begin  
  37.      set @years = @years - 1  
  38.      set @months = @months + 12  
  39.    end  
  40. if @years = 0 and @months = 0  
  41. begin  
  42.      return convert(varchar,@days+1) + '天'  
  43.   end  
  44. if @years > 0  
  45.    set @age = cast(@years as varchar(5)) + '岁'  
  46. if @years < 3 and @months > 0 and @years>-1  
  47. begin  
  48.    set @age = @age + cast(@months as varchar(5)) + '月'  
  49. end  
  50. if @years<0  
  51. set @age=''  
  52. RETURN @age  
  53. END
复制代码
使用函数:

到此这篇关于sql通过日期判定年事函数的示例代码的文章就先容到这了,更多相关sql日期盘算年事内容请搜索草根技术分享从前的文章或继续浏览下面的相关文章希望大家以后多多支持草根技术分享!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作