SQL Server數(shù)據(jù)庫(kù)中的存儲(chǔ)過(guò)程是怎么樣的,相信很多沒(méi)有經(jīng)驗(yàn)的人對(duì)此束手無(wú)策,為此本文總結(jié)了問(wèn)題出現(xiàn)的原因和解決方法,通過(guò)這篇文章希望你能解決這個(gè)問(wèn)題。
創(chuàng)新互聯(lián)專(zhuān)注于達(dá)坂城企業(yè)網(wǎng)站建設(shè),響應(yīng)式網(wǎng)站設(shè)計(jì),成都做商城網(wǎng)站。達(dá)坂城網(wǎng)站建設(shè)公司,為達(dá)坂城等地區(qū)提供建站服務(wù)。全流程按需策劃,專(zhuān)業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,創(chuàng)新互聯(lián)專(zhuān)業(yè)和態(tài)度為您提供的服務(wù)
什么是存儲(chǔ)過(guò)程
如果你接觸過(guò)其他的編程語(yǔ)言,那么就好理解了,存儲(chǔ)過(guò)程就像是方法一樣。
竟然他是方法那么他就有類(lèi)似的方法名,方法要傳遞的變量和返回結(jié)果,所以存儲(chǔ)過(guò)程有存儲(chǔ)過(guò)程名有存儲(chǔ)過(guò)程參數(shù)也有返回值。
存儲(chǔ)過(guò)程的優(yōu)點(diǎn):
存儲(chǔ)過(guò)程的能力大大增強(qiáng)了SQL語(yǔ)言的功能和靈活性。
可保證數(shù)據(jù)的安全性和完整性。
2.通過(guò)存儲(chǔ)過(guò)程可以使沒(méi)有權(quán)限的用戶(hù)在控制之下間接地存取數(shù)據(jù)庫(kù),從而保證數(shù)據(jù)的安全。
3.通過(guò)存儲(chǔ)過(guò)程可以使相關(guān)的動(dòng)作在一起發(fā)生,從而可以維護(hù)數(shù)據(jù)庫(kù)的完整性。
4.在運(yùn)行存儲(chǔ)過(guò)程前,數(shù)據(jù)庫(kù)已對(duì)其進(jìn)行了語(yǔ)法和句法分析,并給出了優(yōu)化執(zhí)行方案。這種已經(jīng)編譯好的過(guò)程
5.可極大地改善SQL語(yǔ)句的性能。
6.可以降低網(wǎng)絡(luò)的通信量。
7.使體現(xiàn)企業(yè)規(guī)則的運(yùn)算程序放入數(shù)據(jù)庫(kù) 但我們?cè)谄渌麛?shù)據(jù)庫(kù)還是可以調(diào)用系統(tǒng)存儲(chǔ)過(guò)程。有一些系統(tǒng)存儲(chǔ)過(guò)程會(huì)在創(chuàng)建新的數(shù)據(jù)庫(kù)的時(shí)候被自動(dòng)創(chuàng)建在當(dāng)前數(shù)據(jù)庫(kù)中。 常用系統(tǒng)存儲(chǔ)過(guò)程有: 代碼如下: exec sp_databases; --查看數(shù)據(jù)庫(kù) exec sp_tables; --查看表 exec sp_columns student;--查看列 exec sp_helpIndex student;--查看索引 exec sp_helpConstraint student;--約束 exec sp_helptext 'sp_stored_procedures';--查看存儲(chǔ)過(guò)程創(chuàng)建定義的語(yǔ)句 exec sp_stored_procedures;exec sp_rename student, stuInfo;--更改表名 exec sp_renamedb myTempDB, myDB;--更改數(shù)據(jù)庫(kù)名稱(chēng) exec sp_defaultdb 'master', 'myDB';--更改登錄名的默認(rèn)數(shù)據(jù)庫(kù) exec sp_helpdb;--數(shù)據(jù)庫(kù)幫助, exec sp_helpdb master;--查詢(xún)數(shù)據(jù)庫(kù)信息 exec sp_attach_db --附加數(shù)據(jù)庫(kù) exec sp_detach_db --分離數(shù)據(jù)庫(kù) 存儲(chǔ)過(guò)程語(yǔ)法: 在創(chuàng)建一個(gè)存儲(chǔ)過(guò)程前,先來(lái)說(shuō)一下存儲(chǔ)過(guò)程的命名,看到好幾篇講存儲(chǔ)過(guò)程的文章都喜歡在創(chuàng)建存儲(chǔ)過(guò)程的時(shí)候加一個(gè)前綴,養(yǎng)成在存儲(chǔ)過(guò)程名前加前綴的習(xí)慣很重要,雖然這只是一件很小的事情,但是往往小細(xì)節(jié)決定大成敗??吹接械娜讼矚g這樣加前綴,例如proc_名字。也看到這加樣前綴usp_名字。前一種proc是procedure的簡(jiǎn)寫(xiě),后一種sup意思是user procedure。我比較喜歡第一種,那么下面所有的存儲(chǔ)過(guò)程名都以第一種來(lái)寫(xiě)。至于名字的寫(xiě)法采用駱駝命名法。 創(chuàng)建存儲(chǔ)過(guò)程的語(yǔ)法如下: 代碼如下: CREATE PROC[EDURE] 存儲(chǔ)過(guò)程名 @參數(shù)1 [數(shù)據(jù)類(lèi)型]=[默認(rèn)值] [OUTPUT] @參數(shù)2 [數(shù)據(jù)類(lèi)型]=[默認(rèn)值] [OUTPUT] AS SQL語(yǔ)句 EXEC 過(guò)程名[參數(shù)] 使用存儲(chǔ)過(guò)程實(shí)例: 1.不帶參數(shù) 代碼如下: create procedure proc_select_officeinfo--(存儲(chǔ)過(guò)程名)as select Id,Name from Office_Info--(sql語(yǔ)句) exec proc_select_officeinfo--(調(diào)用存儲(chǔ)過(guò)程) 2.帶輸入?yún)?shù) 代碼如下: create procedure procedure_proc_GetoffinfoById --(存儲(chǔ)過(guò)程名)@Id int--(參數(shù)名 參數(shù)類(lèi)型)as select Name from dbo.Office_Info where Id=@Id--(sql語(yǔ)句) exec procedure_proc_GetoffinfoById 2--(存儲(chǔ)過(guò)程名稱(chēng)之后,空格加上參數(shù),多個(gè)參數(shù)中間以逗號(hào)分隔) 注:參數(shù)賦值是,第一個(gè)參數(shù)可以不寫(xiě)參數(shù)名稱(chēng),后面?zhèn)魅雲(yún)?shù),需要明確傳入的是哪個(gè)參數(shù)名稱(chēng) 3.帶輸入輸出參數(shù) 代碼如下: create procedure proc_office_info--(存儲(chǔ)過(guò)程名)@Id int,@Name varchar(20) output--(參數(shù)名 參數(shù)類(lèi)型)傳出參數(shù)要加上outputas beginselect @Name=Name from dbo.Office_Info where Id=@Id --(sql語(yǔ)句)enddeclare @houseName varchar(20) --聲明一個(gè)變量,獲取存儲(chǔ)過(guò)程傳出來(lái)的值exec proc_office_info--(存儲(chǔ)過(guò)程名)4,@houseName output--(傳說(shuō)參數(shù)要加output 這邊如果用@變量 = OUTPUT會(huì)報(bào)錯(cuò),所以換一種寫(xiě)法)select @houseName--(顯示值) 4.帶返回值 代碼如下: create procedure proc_office_info--(存儲(chǔ)過(guò)程名)@Id int--(參數(shù)名 參數(shù)類(lèi)型)as beginif(select Name from dbo.Office_Info where Id=@Id)=null --(sql語(yǔ)句)beginreturn -1endelsebeginreturn 1endend declare @house varchar(20) --聲明一個(gè)變量,獲取存儲(chǔ)過(guò)程傳出來(lái)的值exec @house=proc_office_info 2 --(調(diào)用存儲(chǔ)過(guò)程,用變量接收返回值)--注:帶返回值的存儲(chǔ)過(guò)程只能為int類(lèi)型的返回值print @house 看完上述內(nèi)容,你們掌握SQL Server數(shù)據(jù)庫(kù)中的存儲(chǔ)過(guò)程是怎么樣的的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!
網(wǎng)頁(yè)名稱(chēng):SQLServer數(shù)據(jù)庫(kù)中的存儲(chǔ)過(guò)程是怎么樣的
文章URL:http://weahome.cn/article/gigjgp.html