亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > SQL Server > 正文

13、SQL Server 自定義函數

2024-08-31 00:54:04
字體:
來源:轉載
供稿:網友
13、SQL Server 自定義函數

SQLServer自定義函數

在SQLServer中不僅可以使用系統函數(如:聚合函數,字符串函數,時間日期函數等)還可以根據需要自定義函數。

自定義函數分為標量值函數和表值函數。

其中,標量值函數用于返回單個值,而表值函數用于返回一個結果集。

函數參數

參數可以是常量、表中的某個列、表達式或其他類型的值。在函數中有三種類型的參數。

1、輸入:指必須輸入一個值。

2、可選值:在執行該參數時,可以選擇不輸入參數。

3、默認值:函數中默認有值存在,調用時可以不指定該值。

創建標量值函數

語法:

Create function 函數名(參數)Returns 返回值數據類型[with {Encryption | Schemabinding }][as]begin  SQL語句(必須有return 變量或值)EndSchemabinding :將函數綁定到它引用的對象上(注:函數一旦綁定,則不能刪除、修改,除非刪除綁定)

例子:

drop function dbo.input  --刪除函數gocreate function dbo.input --定義函數 架構.方法名(@num1 int,   --輸入參數@num2 int = null,  --可選參數@oper varchar = '+' --默認參數)returns intasbegin    declare @sum int    if(@oper='+')    begin        set @sum = @num1 + @num2    end    else    begin        set @sum = 0    end    return @sumendgoselect dbo.input(1,null,default)  --參1必填,參2可選,參3默認select dbo.input(1,2,default) --輸出3select dbo.input(1,2,'*') --輸出0 *沒判斷

自定義函數可以將值放在局部變量中,用set select exec賦值

declare @number intselect @number = dbo.input(1,2,default)PRint @numberdeclare @set intset @set = dbo.input(1,2,default)print @setdeclare @exec intexec @exec = dbo.input 1,2,'+'print @exec

在查詢中引用函數

create table test(    id int identity(1,1),    name varchar(10),    birthDay datetime)insert into test values('張三','1998-02-01'),('李四','1981-10-1'),('王五','1985-5-2')select * from test --測試信息

創建函數并執行后

create function dbo.getAge(@birthDay datetime)returns intasbegindeclare @age intset @age = datediff(yy,@birthDay,getdate())return @ageendselect name as 姓名,dbo.getAge(birthDay) as 年齡 from test

注意:標量值函數不可以返回文本(text、ntext)、圖像、游標或時間戳類型的數據,并且不能用來修改數據庫狀態。

在select語句中使用函數可能會帶來負面影響,因為每返回一行都會調用函數一次。所以在返回大型數據集時應該格外避免使用復雜的函數。

表值函數

表值函數包含兩種類型:內聯函數和多語句函數。

內聯表值函數僅返回一個結果集,而多語句函數可以在函數體中包含一些控制邏輯。

1、內聯表值函數

語法:

create function 函數名(參數)returns table[with {Encryption | Schemabinding }]asreturn(一條SQL語句)

例子:

--創建create function getDetails(@id int)returns tableasreturn(select * from student where id = @id) --執行一條語句后返回--調用select * from dbo.getDetails(10)

2、多語句函數

多語句函數可以通過多條語句來創建臨時表,具體需要哪些字段,以及符合哪些要求的數據被添加到臨時表中等。

語法:

create function 函數名(參數)returns 表格變量名 table (表格變量定義)[with {Encryption | Schemabinding }]asbegin    SQL語句end 

例子:

create function dbo.Test()returns @temp table (    name varchar(20),    sex char(2),    age int)asbegininsert into @temp (name,sex,age) values ('多語句','嘛',18)insert into @temp (name,sex,age) select name,sex,age from student where age > 18return end

可以看出,多語句函數返回結果是定義好表結構的虛擬表,最后有一個return用來告訴sql多語句已經執行完畢。不寫會返回不了。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人黄色在线观看| 国产精品九九久久久久久久| 51视频国产精品一区二区| 九色精品美女在线| 美女av一区二区| 日韩电影中文字幕在线| 久久久精品网站| 亚洲在线观看视频| 97视频在线免费观看| 亚洲日本中文字幕免费在线不卡| 一级做a爰片久久毛片美女图片| 亚洲第一级黄色片| 色悠悠久久久久| 日韩在线免费视频观看| 国产日韩综合一区二区性色av| 91九色综合久久| 国产97色在线|日韩| 欧美成人午夜剧场免费观看| 欧美性猛交xxxx富婆弯腰| 日韩av在线免费| 亚洲一区二区在线| 午夜精品蜜臀一区二区三区免费| 日产精品久久久一区二区福利| 黑人巨大精品欧美一区二区三区| 精品呦交小u女在线| 国产欧美日韩综合精品| 一区二区三区久久精品| 亚洲一区999| 亚洲国产欧美一区二区三区同亚洲| 日韩欧美有码在线| 国产欧美一区二区三区四区| 国产a∨精品一区二区三区不卡| 欧美日韩视频免费播放| 亚洲精品国产精品国自产观看浪潮| 久久久免费精品视频| 久久偷看各类女兵18女厕嘘嘘| 欧美成人精品不卡视频在线观看| 亚洲影院污污.| 日韩av一区在线| 中文字幕视频在线免费欧美日韩综合在线看| 高清在线视频日韩欧美| 日韩黄在线观看| 国产在线不卡精品| 国外日韩电影在线观看| 高清一区二区三区日本久| 国产精品久久77777| 久久久久久网站| 最好看的2019的中文字幕视频| 欧美电影电视剧在线观看| 久久久久久网址| 北条麻妃一区二区三区中文字幕| 精品免费在线观看| 国产欧美日韩精品在线观看| 精品国产一区二区三区久久| 亚洲国产一区二区三区四区| 亚洲欧美一区二区激情| 国产网站欧美日韩免费精品在线观看| 日产精品久久久一区二区福利| 成人免费在线视频网站| 成人精品aaaa网站| 亚洲美女视频网| 欧美日韩免费观看中文| 国产日韩精品视频| 日韩黄色在线免费观看| 日韩欧美在线视频观看| 欧美日韩中国免费专区在线看| 亚洲成**性毛茸茸| 国产精品综合网站| 91免费观看网站| 国产亚洲精品美女久久久久| 成人在线免费观看视视频| 富二代精品短视频| 国产一区二区三区四区福利| 欧美俄罗斯性视频| 热久久这里只有精品| 亚洲电影免费观看高清完整版在线| 欧美激情免费视频| 成人亚洲综合色就1024| 欧美日韩在线视频一区二区| 一区二区成人精品| 日韩**中文字幕毛片| 国产精品网址在线| 久久久久久噜噜噜久久久精品| 日韩女优人人人人射在线视频| 亚洲欧美中文另类| 国产成人精品最新| 在线a欧美视频| 日韩精品极品视频免费观看| 国产视频久久久| 日韩免费观看av| 中文字幕在线看视频国产欧美在线看完整| 欧美一级大片视频| 精品久久久久久久久久ntr影视| 久久福利网址导航| 法国裸体一区二区| 欧美在线视频观看免费网站| 韩日精品中文字幕| 国产精品丝袜白浆摸在线| 91在线无精精品一区二区| 国产精品视频永久免费播放| 国产自摸综合网| 在线观看久久av| 亚洲无线码在线一区观看| 精品国产一区二区三区久久久| 日韩一区二区三区在线播放| 亚洲图片欧美午夜| 欧美日韩国产精品一区二区不卡中文| 亚洲乱亚洲乱妇无码| 久久综合免费视频| 亚洲人高潮女人毛茸茸| 亚洲精品在线观看www| 亚洲免费一在线| 精品av在线播放| 亚洲国产精品va在线观看黑人| 热re91久久精品国99热蜜臀| 久热精品视频在线观看一区| 欧美乱妇高清无乱码| 美女视频黄免费的亚洲男人天堂| 久久久免费高清电视剧观看| 搡老女人一区二区三区视频tv| 成人自拍性视频| 亚洲精品成人久久电影| 国产精品福利在线| 亚洲激情视频网| 国产中文字幕91| 中文字幕亚洲无线码在线一区| 国产精品久久久久久久7电影| 成人观看高清在线观看免费| 综合久久五月天| 97视频在线观看免费高清完整版在线观看| 国产激情视频一区| 国产精品色悠悠| 国产一区二区三区毛片| 亚洲精品在线看| 国产精品高潮呻吟久久av黑人| 欧美限制级电影在线观看| 国内精品中文字幕| 日韩欧美在线中文字幕| 麻豆精品精华液| 国产一区在线播放| 日韩电视剧在线观看免费网站| 国产精品99久久久久久白浆小说| 日韩av在线网址| 97精品国产aⅴ7777| 在线精品高清中文字幕| 欧美电影免费观看大全| 国产精品www网站| 成人情趣片在线观看免费| 成人免费看黄网站| 国产精品99久久久久久久久久久久| 国产精品夜色7777狼人| 欧美激情视频三区| 色视频www在线播放国产成人| 97国产精品视频| 亚洲国产精品视频在线观看| 欧美性猛交xxxx黑人| 中文字幕欧美国内| 久久中文字幕在线| 日韩大片在线观看视频| 亚洲高清免费观看高清完整版| 精品中文字幕在线观看| 日韩精品在线视频美女| 欧美一级大片视频| 亚洲视频777|