溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

數(shù)據(jù)庫中使用存儲過程的實(shí)例

發(fā)布時(shí)間:2021-01-15 09:58:50 來源:億速云 閱讀:174 作者:小新 欄目:數(shù)據(jù)庫

這篇文章將為大家詳細(xì)講解有關(guān)數(shù)據(jù)庫中使用存儲過程的實(shí)例,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

數(shù)據(jù)庫中使用存儲過程的實(shí)例

什么是存儲過程

如果你接觸過其他的編程語言,那么就好理解了,存儲過程就像是方法一樣。

  竟然他是方法那么他就有類似的方法名,方法要傳遞的變量和返回結(jié)果,所以存儲過程有存儲過程名有存儲過程參數(shù)也有返回值。

  存儲過程的優(yōu)點(diǎn):  

  • 存儲過程的能力大大增強(qiáng)了SQL語言的功能和靈活性。

  • 可保證數(shù)據(jù)的安全性和完整性。

  • 通過存儲過程可以使沒有權(quán)限的用戶在控制之下間接地存取數(shù)據(jù)庫,從而保證數(shù)據(jù)的安全。

  • 通過存儲過程可以使相關(guān)的動(dòng)作在一起發(fā)生,從而可以維護(hù)數(shù)據(jù)庫的完整性。

  • 在運(yùn)行存儲過程前,數(shù)據(jù)庫已對其進(jìn)行了語法和句法分析,并給出了優(yōu)化執(zhí)行方案。這種已經(jīng)編譯好的過程可極大地改善SQL語句的性能。

  • 可以降低網(wǎng)絡(luò)的通信量。

  • 使體現(xiàn)企業(yè)規(guī)則的運(yùn)算程序放入數(shù)據(jù)庫服務(wù)器中,以便 集中控制。

存儲過程可以分為系統(tǒng)存儲過程、擴(kuò)展存儲過程和用戶自定義的存儲過程

系統(tǒng)存儲過程

我們先來看一下系統(tǒng)存儲過程,系統(tǒng)存儲過程由系統(tǒng)定義,主要存放在MASTER數(shù)據(jù)庫中,名稱以"SP"開頭或以"XP"開頭。盡管這些系統(tǒng)存儲過程在MASTER數(shù)據(jù)庫中,

   但我們在其他數(shù)據(jù)庫還是可以調(diào)用系統(tǒng)存儲過程。有一些系統(tǒng)存儲過程會在創(chuàng)建新的數(shù)據(jù)庫的時(shí)候被自動(dòng)創(chuàng)建在當(dāng)前數(shù)據(jù)庫中。

常用系統(tǒng)存儲過程有:

  • exec sp_databases; --查看數(shù)據(jù)庫

  • exec sp_tables;        --查看表

  • exec sp_columns student;--查看列

  • exec sp_helpIndex student;--查看索引

  • exec sp_helpConstraint student;--約束

  • exec sp_helptext 'sp_stored_procedures';--查看存儲過程創(chuàng)建定義的語句

  • exec sp_stored_procedures;

  • exec sp_rename student, stuInfo;--更改表名

  • exec sp_renamedb myTempDB, myDB;--更改數(shù)據(jù)庫名稱

  • exec sp_defaultdb 'master', 'myDB';--更改登錄名的默認(rèn)數(shù)據(jù)庫

  • exec sp_helpdb;--數(shù)據(jù)庫幫助,查詢數(shù)據(jù)庫信息

  • exec sp_helpdb master;

  • exec sp_attach_db --附加數(shù)據(jù)庫

  • exec sp_detach_db --分離數(shù)據(jù)庫

存儲過程語法:

在創(chuàng)建一個(gè)存儲過程前,先來說一下存儲過程的命名,看到好幾篇講存儲過程的文章都喜歡在創(chuàng)建存儲過程的時(shí)候加一個(gè)前綴,養(yǎng)成在存儲過程名前加前綴的習(xí)慣很重要,雖然這只是一件很小的事情,但是往往小細(xì)節(jié)決定大成敗??吹接械娜讼矚g這樣加前綴,例如proc_名字。也看到這加樣前綴usp_名字。前一種proc是procedure的簡寫,后一種sup意思是user procedure。我比較喜歡第一種,那么下面所有的存儲過程名都以第一種來寫。至于名字的寫法采用駱駝命名法。

創(chuàng)建存儲過程的語法如下:

CREATE PROC[EDURE] 存儲過程名 

@參數(shù)1 [數(shù)據(jù)類型]=[默認(rèn)值] [OUTPUT] 

@參數(shù)2 [數(shù)據(jù)類型]=[默認(rèn)值] [OUTPUT]

AS 

SQL語句

EXEC 過程名[參數(shù)]

使用存儲過程實(shí)例:

1.不帶參數(shù)

create procedure proc_select_officeinfo--(存儲過程名)as select Id,Name from Office_Info--(sql語句)

exec proc_select_officeinfo--(調(diào)用存儲過程)

2.帶輸入?yún)?shù)

create procedure procedure_proc_GetoffinfoById ----  Name  dbo.Office_Info  Id=@Id----(存儲過程名稱之后,空格加上參數(shù),多個(gè)參數(shù)中間以逗號分隔)

注:參數(shù)賦值是,第一個(gè)參數(shù)可以不寫參數(shù)名稱,后面?zhèn)魅雲(yún)?shù),需要明確傳入的是哪個(gè)參數(shù)名稱

3.帶輸入輸出參數(shù)

create procedure proc_office_info--(存儲過程名)
@Id int,@Name varchar(20) output--(參數(shù)名 參數(shù)類型)傳出參數(shù)要加上output
as
begin
select @Name=Name from dbo.Office_Info where Id=@Id --(sql語句)
end

declare @houseName varchar(20) --聲明一個(gè)變量,獲取存儲過程傳出來的值
exec proc_office_info--(存儲過程名)
4,@houseName output--(傳說參數(shù)要加output 這邊如果用@變量 = OUTPUT會報(bào)錯(cuò),所以換一種寫法)

select @houseName--(顯示值)

4.帶返回值的

create procedure proc_office_info--(存儲過程名)
@Id int--(參數(shù)名 參數(shù)類型)as beginif(select Name from dbo.Office_Info where Id=@Id)=null --(sql語句)
beginreturn -1endelsebeginreturn 1end
end

declare @house varchar(20) --聲明一個(gè)變量,獲取存儲過程傳出來的值
exec @house=proc_office_info 2 --(調(diào)用存儲過程,用變量接收返回值)--注:帶返回值的存儲過程只能為int類型的返回值
print @house

關(guān)于“數(shù)據(jù)庫中使用存儲過程的實(shí)例”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯(cuò),請把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI