Sql server-自定义函数

定义:一种方法

1.创建函数,求该银行的金额总和--(没有参数,返回标量值)

go

create function getsumcardbalance()

return money

as

begin

declare @sumcardbalance money

set @sumcardbalance =(select sum(cardbalance) from bankcard)

return @sumcardbalance 

end

2.调用验证

select dbo.getsumcardbalance() 银行金额总和

3.删除函数

drop function getsumcardbalance

4.创建函数:传入账户编号(假设accid=1),返回账户真实姓名

go

create function getrealname(@accid int)

returns nvarchar(30)

as

begin

declare @realname nvarchar(30)

set @realname =(select accname from accountinfo where accid=@accid)

return @realname

end

go

调用函数

select dbo.getrealname(1)

删除函数

drop function getrealname

验证是否删除成功

select dbo.getrealname(1)

创建函数:传递开始时间和结束时间,返回交易记录(存钱取钱),交易记录中包含真实姓名,卡号,存钱金额,取钱金额,交易时间,用中文标识别名

go

create function getcardchange(@start datetime, @end datetime)

returns @result table 

{

真实姓名 nvarchar(30),

卡号 varchar(30),

存钱金额 money,

取钱金额 money,

交易时间 datetime

}

as 

begin

insert into @result

select accname,bankcard.cardno,moneyin,moneyout,cextime

from bankcard inner join accountinfo

on bankcard ,accid = accountinfo.accid

inner join cardexchange

on bankcard.cardno = cardexchange.cardno

where cextime between @start and @end

return

end

go

调用函数

select * from cardexchange

select * from dbo.getcardchange('2022-11-25','2022-12-25')

--总结: datetime数据类型,如果值输入日期date部分,而不输入time部分,则默认time=00:00:00,

如果需要明确时间范围,需要明确time值。

删除函数

drop function getcardchange

不创建函数:查询银行卡信息,将银行卡状态1.2.3.4分别转换为汉字“正常,挂失,冻结,注销”

select *,case cardstate

when 1 then '正常'

when 2 then '挂失'

when 3 then '冻结'

when 4 then '冻结'

end 银行卡状态

from bankcard

不创建函数,根据银行卡余额显示银行卡等级30万以下为“普通用户”,30万及以上为“vip用户”

select *,case 

 

when cardbalance > 300000 then 'VIP用户'

else '普通用户'

end 用户等级

from bankcard

创建函数:分别显示卡号、身份证,姓名,用户等级,银行卡状态,

select cardno 卡号,accident 身份证,accname 姓名,cardbalance 余额,dbo.getuserrank(cardbalance) 用户等级,dbo.getcardstate(cardstate) 银行卡状态 from bankcard inner join accountinfo 

on bankcard,accid = accountinfo.accid

编写求用户等级函数

go

create function getuserrank (@cardbalance money)

returns nvarchar(30)

as

begin

declare @userrank nvarchar(30)

set @userrank =(select cardbalance from bankcard)

return @userrank

end

go

编辑求银行卡状态函数

go

create function getcardstate(@cardstate int)

returns nvarchar(30)

as 

begin

deciare @state nvarchar(30)

if @cardstate = 1

set @state ='正常'

else if @cardstate = 2

set @state ='挂失'

else if @cardstate = 3

set @state ='冻结'

else if @cardstate = 4

set @state ='注销'

return @state

end

go

编写函数,根据出生日期求实岁年龄,例如

生日为2000-5-5,当前为2020-5-4,年龄为19岁

生日为2000-5-5,当前为2020-5-6,年龄为20岁

分析思路,定义出生日期:@dirthday,@getrealage:

--1.year(getdata())=year(@birthday),@getrealage =0

 

--2.year(getdate()) >year(@birthday) and month(getdate())>month(@birthday),@getrealage=year(getdate())-year(@birthday)

--3.year(getdate()) >year(@birthday) and month(getdate()) = month(@birthday) and day(getdate()) >= day(@birthday),@getrealage=year(getdate())-year(@birthday)

 

--4. year(getdate()) > year(@birthday) and month(getdate())=month(@birthday) and day(getdate()) < day(@birthday),@getrealage=year(getdate())-year(@birthday)-1

--5. year(getdate()) > year(@birthday) and month(getdate())<month(@birthday) ,@getrealage=year(getdate())-year(@birthday)-1

 

go

create function getrealage(@birthday datetime)

returns int 

as

begin

declard @age int 

if  year(getdata())=year(@birthday)

set @age =0

 

else if year(getdate()) >year(@birthday) and month(getdate())>month(@birthday)

set @age=year(getdate())-year(@birthday)

 

else if year(getdate()) >year(@birthday) and month(getdate()) = month(@birthday) and day(getdate()) >= day(@birthday)

set @age=year(getdate())-year(@birthday)

 

else

set  @age=year(getdate())-year(@birthday) -1

 

return @age

end

go

验证:当年出生的‘2022-1-23’

select dbo.getrealage('2022-1-23')

跨年的且当前月份大于出生月份的‘2020-10-23’

select dbo.getrealage('2022-10-23')

跨年的且当前月份等于出生月份的且当前日期=出生日期 “2020-11-27”

select dbo.getrealage('2022-11-27')

跨年的且当前月份等于出生月份的且当前日期》出生日期‘2020-11-21’

select dbo.getrealage('2020-11-23')

跨年的且当前月份等于出生月份的且当前日期<出生日期‘2020-11-28’

select dbo.getrealage('2020-11-28')

跨年的且当前月份小于出生月份‘2020-12-21’

select dbo.getrealage('2020-11-28')

 

posted @ 2023-08-19 13:47  KevinSteven  阅读(132)  评论(0编辑  收藏  举报