欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

SQLServer數(shù)據(jù)庫中的存儲過程是怎么樣的

SQL Server數(shù)據(jù)庫中的存儲過程是怎么樣的,相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。

創(chuàng)新互聯(lián)專注于達坂城企業(yè)網(wǎng)站建設,響應式網(wǎng)站設計,成都做商城網(wǎng)站。達坂城網(wǎng)站建設公司,為達坂城等地區(qū)提供建站服務。全流程按需策劃,專業(yè)設計,全程項目跟蹤,創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務

什么是存儲過程

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

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

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

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

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

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

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

4.在運行存儲過程前,數(shù)據(jù)庫已對其進行了語法和句法分析,并給出了優(yōu)化執(zhí)行方案。這種已經(jīng)編譯好的過程

5.可極大地改善SQL語句的性能。

6.可以降低網(wǎng)絡的通信量。

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

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

系統(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ù)庫的時候被自動創(chuà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';--更改登錄名的默認數(shù)據(jù)庫

exec sp_helpdb;--數(shù)據(jù)庫幫助,

exec sp_helpdb master;--查詢數(shù)據(jù)庫信息

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

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

存儲過程語法:

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

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

 代碼如下: 

CREATE PROC[EDURE] 存儲過程名

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

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

AS

SQL語句

EXEC 過程名[參數(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 --(存儲過程名)@Id int--(參數(shù)名 參數(shù)類型)as select Name from dbo.Office_Info where Id=@Id--(sql語句)

exec procedure_proc_GetoffinfoById 2--(存儲過程名稱之后,空格加上參數(shù),多個參數(shù)中間以逗號分隔)

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

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

 代碼如下: 

create procedure proc_office_info--(存儲過程名)@Id int,@Name varchar(20) output--(參數(shù)名 參數(shù)類型)傳出參數(shù)要加上outputas beginselect @Name=Name from dbo.Office_Info where Id=@Id --(sql語句)enddeclare @houseName varchar(20) --聲明一個變量,獲取存儲過程傳出來的值exec proc_office_info--(存儲過程名)4,@houseName output--(傳說參數(shù)要加output 這邊如果用@變量 = OUTPUT會報錯,所以換一種寫法)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 1endend

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

看完上述內(nèi)容,你們掌握SQL Server數(shù)據(jù)庫中的存儲過程是怎么樣的的方法了嗎?如果還想學到更多技能或想了解更多相關內(nèi)容,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!

分享文章:SQLServer數(shù)據(jù)庫中的存儲過程是怎么樣的
文章出自:http://chinadenli.net/article18/gigjgp.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站建設面包屑導航、軟件開發(fā)網(wǎng)站策劃、建站公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

手機網(wǎng)站建設