服务器之家

服务器之家 > 正文

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

时间:2021-08-21 21:53     来源/作者:kueizheng

定义函数:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
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通过日期判断年龄函数的示例代码的文章就介绍到这了,更多相关sql日期计算年龄内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://www.cnblogs.com/Allofus/p/15016007.html

标签:

相关文章

热门资讯

yue是什么意思 网络流行语yue了是什么梗
yue是什么意思 网络流行语yue了是什么梗 2020-10-11
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
背刺什么意思 网络词语背刺是什么梗
背刺什么意思 网络词语背刺是什么梗 2020-05-22
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总 2020-11-13
2021年耽改剧名单 2021要播出的59部耽改剧列表
2021年耽改剧名单 2021要播出的59部耽改剧列表 2021-03-05
返回顶部