自定义函数

--自定义函数

--自定义函数分为:标量函数和表值函数(内联表值函数和多语句表值函数)

--标量函数:只返回一个基础类型数据的值,这样的函数叫做标量函数

--表值函数:返回一个table类型的结果集

 

--标量函数语法

--create function 函数名

--([参数列表])

--returns 返回值类型

--as

--begin

-- ...函数体语句

-- return 返回值

--end

--练习:把根据性别,求全班数学平均分封装成一个函数

create function Fun_GetAvgMathByGender(@gender nvarchar(1))

returns float

as

  begin

     declare @count int

     set @count=0

     declare @sum int

     set @sum=0

     declare @bitgender bit

     if(@gender='男')

       begin

         set @bitgender=1

       end

     else

       begin

         set @bitgender=0

       end

     select @count=count(1) from score join student on student.id=score.stuId where gender=@bitgender

     select @sum=SUM(math) from score join student on student.id=score.stuId where gender=@bitgender

     declare @average float

     set @average=@sum/@count

return @average

  end

 

--函数调用,函数名前要加dbo.

select dbo.Fun_getAvgMathByGender('男')

 

--注意:1.SQL中自定义函数必须有返回值

--   2.在自定义函数中,不允许修改基表内容,也就是说不允许

--   在函数中使用insert、update、delete语句

--   3.如果参数列表中有多个参数,每个参数之间用,隔开

--   4.函数调用,函数名前要加dbo.

 

 

--内联表值函数

--语法:

--create function 函数名

--([参数列表])

--reeturns table

--as

--return(一条select语句)

--练习:根据性别,查询所有该性别所有的学生的学号,姓名,年龄,班级名,班主任

create function Fun_getStudeentInfoByGender(@gender bit)

returns table

as

return (select stuNo,stuName,DATEDIFF(year,birthday,GETDATE()) as age,

clsName,clsTeacher

 from student join Class on student.clsId=Class.Id where gender=@gender)

 

 --1.内联表值函数return后边只能有一条select语句

 --2.内联表值函数as后边不能跟begin...end

 --3.调用内联表值函数是,需要向查询视图一样对待

 select * from dbo.Fun_getStudeentInfoByGender(0)

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值