麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 數據庫 > 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手机免费在线观看 | 五月婷婷第四色 | 蜜桃成品人免费视频 | 日韩欧美动作影片 | 欧美日韩在线视频一区二区 | 日韩视频区 | 亚洲综合网站 | 国产一级毛片不卡 | 亚洲免费视 | 日本网站一区二区三区 | 一级毛片真人免费播放视频 | 黄色午夜剧场 | 草妞视频 | 日本羞羞影院 | 日本在线不卡一区二区 | 精品国产精品久久 | 欧美一级棒 | 一区二区三区视频在线观看 | 欧美成人三级视频 | 欧美成人午夜 | 香蕉视频99 | 91精品久久久久久久久久久 | 精品一区二区三区在线观看国产 | 亚洲影院在线播放 | 久久99国产综合精品 | 欧美精品免费一区二区三区 | 欧美巨根| 欧美一区二区网站 | 欧美一级黄色免费看 | av不卡免费在线 | 中文字幕一区二区三区久久 | 日韩美香港a一级毛片免费 欧美一级淫片007 | 久久久久久久久久网 | 一区二区三区日本在线观看 | 蝌蚪久久窝 |