共計 2459 個字符,預計需要花費 7 分鐘才能閱讀完成。
SQL Server 數據庫中的存儲過程是怎么樣的,相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
什么是存儲過程
如果你接觸過其他的編程語言,那么就好理解了,存儲過程就像是方法一樣。
竟然他是方法那么他就有類似的方法名,方法要傳遞的變量和返回結果,所以存儲過程有存儲過程名有存儲過程參數也有返回值。
存儲過程的優點:
存儲過程的能力大大增強了 SQL 語言的功能和靈活性。
可保證數據的安全性和完整性。
2. 通過存儲過程可以使沒有權限的用戶在控制之下間接地存取數據庫,從而保證數據的安全。
3. 通過存儲過程可以使相關的動作在一起發生,從而可以維護數據庫的完整性。
4. 在運行存儲過程前,數據庫已對其進行了語法和句法分析,并給出了優化執行方案。這種已經編譯好的過程
5. 可極大地改善 SQL 語句的性能。
6. 可以降低網絡的通信量。
7. 使體現企業規則的運算程序放入數據庫服務器中,以便集中控制。
存儲過程可以分為系統存儲過程、擴展存儲過程和用戶自定義的存儲過程
系統存儲過程
我們先來看一下系統存儲過程,系統存儲過程由系統定義,主要存放在 MASTER 數據庫中,名稱以 SP 開頭或以 XP 開頭。盡管這些系統存儲過程在 MASTER 數據庫中,
但我們在其他數據庫還是可以調用系統存儲過程。有一些系統存儲過程會在創建新的數據庫的時候被自動創建在當前數據庫中。
常用系統存儲過程有:
代碼如下:
exec sp_databases; – 查看數據庫
exec sp_tables; – 查看表
exec sp_columns student;– 查看列
exec sp_helpIndex student;– 查看索引
exec sp_helpConstraint student;– 約束
exec sp_helptext sp_stored_procedures – 查看存儲過程創建定義的語句
exec sp_stored_procedures;exec sp_rename student, stuInfo;– 更改表名
exec sp_renamedb myTempDB, myDB;– 更改數據庫名稱
exec sp_defaultdb master , myDB – 更改登錄名的默認數據庫
exec sp_helpdb;– 數據庫幫助,
exec sp_helpdb master;– 查詢數據庫信息
exec sp_attach_db – 附加數據庫
exec sp_detach_db – 分離數據庫
存儲過程語法:
在創建一個存儲過程前,先來說一下存儲過程的命名,看到好幾篇講存儲過程的文章都喜歡在創建存儲過程的時候加一個前綴,養成在存儲過程名前加前綴的習慣很重要,雖然這只是一件很小的事情,但是往往小細節決定大成敗??吹接械娜讼矚g這樣加前綴,例如 proc_名字。也看到這加樣前綴 usp_名字。前一種 proc 是 procedure 的簡寫,后一種 sup 意思是 user procedure。我比較喜歡第一種,那么下面所有的存儲過程名都以第一種來寫。至于名字的寫法采用駱駝命名法。
創建存儲過程的語法如下:
代碼如下:
CREATE PROC[EDURE] 存儲過程名
@參數 1 [數據類型]=[默認值] [OUTPUT]
@參數 2 [數據類型]=[默認值] [OUTPUT]
AS
SQL 語句
EXEC 過程名 [參數]
使用存儲過程實例:
1. 不帶參數
代碼如下:
create procedure proc_select_officeinfo–(存儲過程名)as select Id,Name from Office_Info–(sql 語句)
exec proc_select_officeinfo–(調用存儲過程)
2. 帶輸入參數
代碼如下:
create procedure procedure_proc_GetoffinfoById –(存儲過程名)@Id int–(參數名 參數類型)as select Name from dbo.Office_Info where Id=@Id–(sql 語句)
exec procedure_proc_GetoffinfoById 2–(存儲過程名稱之后, 空格加上參數, 多個參數中間以逗號分隔)
注: 參數賦值是, 第一個參數可以不寫參數名稱, 后面傳入參數, 需要明確傳入的是哪個參數名稱
3. 帶輸入輸出參數
代碼如下:
create procedure proc_office_info–(存儲過程名)@Id int,@Name varchar(20) output–(參數名 參數類型) 傳出參數要加上 outputas beginselect @Name=Name from dbo.Office_Info where Id=@Id –(sql 語句)enddeclare @houseName varchar(20) – 聲明一個變量, 獲取存儲過程傳出來的值 exec proc_office_info–(存儲過程名)4,@houseName output–(傳說參數要加 output 這邊如果用 @變量 = OUTPUT 會報錯,所以換一種寫法)select @houseName–(顯示值)
4. 帶返回值
代碼如下:
create procedure proc_office_info–(存儲過程名)@Id int–(參數名 參數類型)as beginif(select Name from dbo.Office_Info where Id=@Id)=null –(sql 語句)beginreturn -1endelsebeginreturn 1endend
declare @house varchar(20) – 聲明一個變量, 獲取存儲過程傳出來的值 exec @house=proc_office_info 2 –(調用存儲過程, 用變量接收返回值)– 注:帶返回值的存儲過程只能為 int 類型的返回值 print @house
看完上述內容,你們掌握 SQL Server 數據庫中的存儲過程是怎么樣的的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注丸趣 TV 行業資訊頻道,感謝各位的閱讀!