国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 網站 > 建站經驗 > 正文

SQL Server數據庫 中的存儲過程介紹

2019-11-02 15:24:29
字體:
來源:轉載
供稿:網友

 什么是存儲過程

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

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

存儲過程的優點:   

存儲過程的能力大大增強了SQL語言的功能和靈活性。

1.可保證數據的安全性和完整性。
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--(存儲過程名稱之后,空格加上參數,多個參數中間以逗號分隔)

注:參數賦值是,第一個參數可以不寫參數名稱,后面傳入參數,需要明確傳入的是哪個參數名稱

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 石楼县| 天水市| 依兰县| 永春县| 长子县| 抚顺市| 阿图什市| 谢通门县| SHOW| 茌平县| 乐平市| 乌审旗| 祁连县| 岑巩县| 荥经县| 精河县| 云南省| 巴彦淖尔市| 韩城市| 广昌县| 榆中县| 垫江县| 怀柔区| 河池市| 高阳县| 富平县| 冕宁县| 新宁县| 正镶白旗| 玉山县| 沛县| 临邑县| 阿尔山市| 蕲春县| 江陵县| 酉阳| 印江| 泰兴市| 陕西省| 乌兰浩特市| 盐山县|