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

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

談談sqlserver自定義函數與存儲過程的區別

2024-08-31 01:02:31
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了談談sqlserver自定義函數與存儲過程的區別,需要的朋友可以參考下
 
 

一、自定義函數:

  1. 可以返回表變量
  2. 限制頗多,包括
    不能使用output參數;
    不能用臨時表;
    函數內部的操作不能影響到外部環境;
    不能通過select返回結果集;
    不能update,delete,數據庫表;
  3. 必須return 一個標量值或表變量
  自定義函數一般用在復用度高,功能簡單單一,爭對性強的地方。

二、存儲過程

  1. 不能返回表變量
  2. 限制少,可以執行對數據庫表的操作,可以返回數據集
  3. 可以return一個標量值,也可以省略return
   存儲過程一般用在實現復雜的功能,數據操縱方面。
 
=========================================================================
SqlServer存儲過程--實例
實例1:只返回單一記錄集的存儲過程。
  表銀行存款表(bankMoney)的內容如下
 
Id
userID
Sex
Money
001
Zhangsan

30
002
Wangwu

50
003
Zhangsan

40
 
要求1:查詢表bankMoney的內容的存儲過程

create procedure sp_query_bankMoneyasselect * from bankMoneygoexec sp_query_bankMoney

注* 在使用過程中只需要把T-Sql中的SQL語句替換為存儲過程名,就可以了很方便吧!
實例2(向存儲過程中傳遞參數):

加入一筆記錄到表bankMoney,并查詢此表中userID= Zhangsan的所有存款的總金額。

Create proc insert_bank @param1 char(10),@param2 varchar(20),@param3 varchar(20),@param4 int,@param5 int outputwith encryption ---------加密asinsert into bankMoney (id,userID,sex,Money)Values(@param1,@param2,@param3, @param4)select @param5=sum(Money) from bankMoney where userID='Zhangsan'go在SQL Server查詢分析器中執行該存儲過程的方法是:declare @total_price intexec insert_bank '004','Zhangsan','男',100,@total_price outputprint '總余額為'+convert(varchar,@total_price)go

在這里再啰嗦一下存儲過程的3種傳回值(方便正在看這個例子的朋友不用再去查看語法內容):
1.以Return傳回整數
2.以output格式傳回參數
3.Recordset

傳回值的區別:

output和return都可在批次程式中用變量接收,而recordset則傳回到執行批次的客戶端中。
實例3:使用帶有復雜 SELECT 語句的簡單過程
  下面的存儲過程從四個表的聯接中返回所有作者(提供了姓名)、出版的書籍以及出版社。該存儲過程不使用任何參數。

USE pubsIF EXISTS (SELECT name FROM sysobjects     WHERE name = 'au_info_all' AND type = 'P')  DROP PROCEDURE au_info_allGOCREATE PROCEDURE au_info_allASSELECT au_lname, au_fname, title, pub_name  FROM authors a INNER JOIN titleauthor ta   ON a.au_id = ta.au_id INNER JOIN titles t   ON t.title_id = ta.title_id INNER JOIN publishers p   ON t.pub_id = p.pub_idGO  au_info_all 存儲過程可以通過以下方法執行:  EXECUTE au_info_all-- OrEXEC au_info_all  如果該過程是批處理中的第一條語句,則可使用:  au_info_all

實例4:使用帶有參數的簡單過程

  CREATE PROCEDURE au_info  @lastname varchar(40),  @firstname varchar(20)ASSELECT au_lname, au_fname, title, pub_name  FROM authors a INNER JOIN titleauthor ta   ON a.au_id = ta.au_id INNER JOIN titles t   ON t.title_id = ta.title_id INNER JOIN publishers p   ON t.pub_id = p.pub_id  WHERE au_fname = @firstname   AND au_lname = @lastnameGO  au_info 存儲過程可以通過以下方法執行:  EXECUTE au_info 'Dull', 'Ann'-- OrEXECUTE au_info @lastname = 'Dull', @firstname = 'Ann'-- OrEXECUTE au_info @firstname = 'Ann', @lastname = 'Dull'-- OrEXEC au_info 'Dull', 'Ann'-- OrEXEC au_info @lastname = 'Dull', @firstname = 'Ann'-- OrEXEC au_info @firstname = 'Ann', @lastname = 'Dull'  如果該過程是批處理中的第一條語句,則可使用:  au_info 'Dull', 'Ann'-- Orau_info @lastname = 'Dull', @firstname = 'Ann'-- Orau_info @firstname = 'Ann', @lastname = 'Dull'

實例5:使用帶有通配符參數的簡單過程

CREATE PROCEDURE au_info2@lastname varchar(30) = 'D%',@firstname varchar(18) = '%'ASSELECT au_lname, au_fname, title, pub_nameFROM authors a INNER JOIN titleauthor ta  ON a.au_id = ta.au_id INNER JOIN titles t  ON t.title_id = ta.title_id INNER JOIN publishers p  ON t.pub_id = p.pub_idWHERE au_fname LIKE @firstname  AND au_lname LIKE @lastnameGO  au_info2 存儲過程可以用多種組合執行。下面只列出了部分組合:  EXECUTE au_info2-- OrEXECUTE au_info2 'Wh%'-- OrEXECUTE au_info2 @firstname = 'A%'-- OrEXECUTE au_info2 '[CK]ars[OE]n'-- OrEXECUTE au_info2 'Hunter', 'Sheryl'-- OrEXECUTE au_info2 'H%', 'S%'  = 'proc2'

實例6:if...else
存儲過程,其中@case作為執行update的選擇依據,用if...else實現執行時根據傳入的參數執行不同的修改.

--下面是if……else的存儲過程:if exists (select 1 from sysobjects where name = 'Student' and type ='u' )drop table Studentgoif exists (select 1 from sysobjects where name = 'spUpdateStudent' and type ='p' )drop proc spUpdateStudentgocreate table Student(fName nvarchar (10),fAgesmallint ,fDiqu varchar (50),fTel int)goinsert into Student values ('X.X.Y' , 28, 'Tesing' , 888888)gocreate proc spUpdateStudent(@fCase int ,@fName nvarchar (10),@fAge smallint ,@fDiqu varchar (50),@fTel int)asupdate Studentset fAge = @fAge, -- 傳 1,2,3 都要更新 fAge 不需要用 casefDiqu = (case when @fCase = 2 or @fCase = 3 then @fDiqu else fDiqu end ),fTel = (case when @fCase = 3 then @fTel else fTel end )where fName = @fNameselect * from Studentgo-- 只改 Ageexec spUpdateStudent@fCase = 1,@fName = N'X.X.Y' ,@fAge = 80,@fDiqu = N'Update' ,@fTel = 1010101-- 改 Age 和 Diquexec spUpdateStudent@fCase = 2,@fName = N'X.X.Y' ,@fAge = 80,@fDiqu = N'Update' ,@fTel = 1010101-- 全改exec spUpdateStudent@fCase = 3,@fName = N'X.X.Y' ,@fAge = 80,@fDiqu = N'Update' ,@fTel = 1010101

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲iv一区二区三区| 日韩精品在线免费观看| 91精品国产91久久久久久最新| 欧美裸体视频网站| 久久噜噜噜精品国产亚洲综合| 欧美性在线观看| 日韩精品一区二区三区第95| 欧美日韩中文在线| 欧美日韩国产一区二区三区| 亚洲欧美一区二区三区情侣bbw| 亚洲视频精品在线| 国产成一区二区| 久久全球大尺度高清视频| 日韩精品一二三四区| 色诱女教师一区二区三区| 亚洲精品免费网站| 97碰碰碰免费色视频| 欧美性xxxx极品hd欧美风情| 亚洲精品一区二区三区婷婷月| 亚洲国产精品99| 视频在线一区二区| 欧美又大又硬又粗bbbbb| 91麻豆桃色免费看| 日韩免费在线电影| 日本精品中文字幕| 亚洲欧美日韩一区二区在线| 欧美日本精品在线| 97av在线播放| 亚洲国产毛片完整版| 成人精品视频99在线观看免费| 亚洲成年人影院在线| 亚洲午夜国产成人av电影男同| 欧美国产欧美亚洲国产日韩mv天天看完整| 九九热视频这里只有精品| 成人亚洲综合色就1024| 97色伦亚洲国产| 欧美日本高清视频| 久久福利网址导航| 成人xxxx视频| 97精品一区二区视频在线观看| 久久亚洲影音av资源网| 中文字幕欧美在线| 国产日韩精品视频| 日韩国产欧美区| 国产精品高潮视频| 欧美性xxxxx极品| 亚洲美女www午夜| 91成人精品网站| 亚洲韩国欧洲国产日产av| 精品久久久久久国产| 国产精品一区二区av影院萌芽| 欧美在线视频网| 日韩有码在线电影| 中文字幕在线看视频国产欧美在线看完整| 欧美视频免费在线| 欧美精品在线播放| 97视频在线观看视频免费视频| 少妇高潮久久久久久潘金莲| 日本中文字幕成人| 亚洲自拍偷拍一区| 日韩av网站在线| 91亚洲国产成人久久精品网站| 中文字幕欧美亚洲| 欧美在线欧美在线| 欧美成人在线免费视频| 成人在线视频网站| 亚洲人成毛片在线播放| 欧美激情视频给我| 久久手机免费视频| 亚洲乱码一区av黑人高潮| 久久视频国产精品免费视频在线| 日韩美女激情视频| 国产精品中文字幕久久久| 57pao国产精品一区| 岛国精品视频在线播放| 在线精品国产成人综合| 亚洲成人a级网| 久久久久久这里只有精品| 黑人精品xxx一区| 亚洲图片制服诱惑| 欧美激情第6页| 日本久久久久久久久久久| 在线免费看av不卡| 精品国产鲁一鲁一区二区张丽| 97视频在线观看播放| 久久精品91久久香蕉加勒比| 伊人久久综合97精品| 亚洲精品日韩在线| 日韩av在线直播| 亚洲a在线观看| 精品国产一区二区三区久久狼5月| 国产午夜精品视频免费不卡69堂| 亚洲乱码国产乱码精品精| 97超级碰碰人国产在线观看| 国产不卡精品视男人的天堂| 深夜福利日韩在线看| 成人精品网站在线观看| 成人免费激情视频| 日韩乱码在线视频| 国产精品久久久久久久久借妻| 亚洲欧美日韩精品久久奇米色影视| 久久艹在线视频| 日韩在线中文视频| 亚洲国产成人久久综合一区| 日本欧美国产在线| 亚洲电影免费观看高清完整版在线| 日韩高清电影免费观看完整| 国产69久久精品成人看| 色哟哟入口国产精品| 日本韩国欧美精品大片卡二| 亚洲区bt下载| 欧美日韩一区二区免费在线观看| 欧美日韩国产第一页| 国产精品免费久久久| 欧美激情按摩在线| 日本亚洲欧美成人| 亚洲精品视频播放| 亚洲第一综合天堂另类专| 亚洲国产成人91精品| 亚洲高清久久网| 在线精品国产成人综合| 久久亚洲私人国产精品va| 91精品国产91久久久久福利| 欧美裸体xxxx极品少妇软件| 美女国内精品自产拍在线播放| 欧美最猛性xxxxx(亚洲精品)| 在线视频亚洲欧美| 亚洲国产成人91精品| 欧美专区日韩视频| 亚洲一级免费视频| 亚洲伊人久久大香线蕉av| 一区二区三区精品99久久| 国产在线999| 国内精品久久久久影院优| 欧美xxxx18性欧美| 亚洲国产一区二区三区四区| 91精品国产99久久久久久| 欧美成年人视频网站欧美| 欧美丰满片xxx777| 中文字幕精品久久久久| 亚洲欧洲自拍偷拍| 欧美激情手机在线视频| 欧美国产精品人人做人人爱| 国产精品香蕉在线观看| 精品国产精品自拍| 97免费视频在线播放| 久久精品99无色码中文字幕| 欧美激情欧美激情| 久久五月情影视| 欧美激情精品久久久久久| 欧美激情按摩在线| 亚洲一区中文字幕在线观看| 日韩在线视频导航| 国产精品成人观看视频国产奇米| 久久久久久一区二区三区| 97人人模人人爽人人喊中文字| 九九综合九九综合| 精品国产一区二区三区久久| 亚洲女人被黑人巨大进入| 亚洲国产成人一区| 国产精品日韩专区| 久久精品国产亚洲精品2020| xxx欧美精品| 68精品国产免费久久久久久婷婷|