婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > SQL Server數(shù)據(jù)庫(kù)中的存儲(chǔ)過(guò)程介紹

SQL Server數(shù)據(jù)庫(kù)中的存儲(chǔ)過(guò)程介紹

熱門(mén)標(biāo)簽:洛陽(yáng)外呼系統(tǒng)平臺(tái) 400外呼系統(tǒng)合法 怎樣把地圖標(biāo)注導(dǎo)入公司地址 真人語(yǔ)音電銷(xiāo)機(jī)器人 電銷(xiāo)機(jī)器人被曝光 地圖標(biāo)注一個(gè)圓圈怎么用 廣州人工電銷(xiāo)機(jī)器人費(fèi)用 寧波人工外呼系統(tǒng)有效果嗎 如何在地圖標(biāo)注自己店鋪

什么是存儲(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ǔ)言的功能和靈活性。

1.可保證數(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ù)服務(wù)器中,以便 集中控制。

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

系統(tǒng)存儲(chǔ)過(guò)程

我們先來(lái)看一下系統(tǒng)存儲(chǔ)過(guò)程,系統(tǒng)存儲(chǔ)過(guò)程由系統(tǒng)定義,主要存放在MASTER數(shù)據(jù)庫(kù)中,名稱(chēng)以"SP"開(kāi)頭或以"XP"開(kāi)頭。盡管這些系統(tǒng)存儲(chǔ)過(guò)程在MASTER數(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ò)程有:

復(fù)制代碼 代碼如下:

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ù)幫助,查詢(xún)數(shù)據(jù)庫(kù)信息
exec sp_helpdb master;
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é)決定大成敗。看到有的人喜歡這樣加前綴,例如proc_名字。也看到這加樣前綴usp_名字。前一種proc是procedure的簡(jiǎn)寫(xiě),后一種sup意思是user procedure。我比較喜歡第一種,那么下面所有的存儲(chǔ)過(guò)程名都以第一種來(lái)寫(xiě)。至于名字的寫(xiě)法采用駱駝命名法。

創(chuàng)建存儲(chǔ)過(guò)程的語(yǔ)法如下:

復(fù)制代碼 代碼如下:

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ù)

復(fù)制代碼 代碼如下:

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ù)
復(fù)制代碼 代碼如下:

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ù)

復(fù)制代碼 代碼如下:

create procedure proc_office_info--(存儲(chǔ)過(guò)程名)
@Id int,@Name varchar(20) output--(參數(shù)名 參數(shù)類(lèi)型)傳出參數(shù)要加上output
as
begin
select @Name=Name from dbo.Office_Info where Id=@Id --(sql語(yǔ)句)
end
declare @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.帶返回值的

復(fù)制代碼 代碼如下:

create procedure proc_office_info--(存儲(chǔ)過(guò)程名)
@Id int--(參數(shù)名 參數(shù)類(lèi)型)
as
begin
if(select Name from dbo.Office_Info where Id=@Id)=null --(sql語(yǔ)句)
begin
return -1
end
else
begin
return 1
end
end

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

您可能感興趣的文章:
  • SQLserver 數(shù)據(jù)庫(kù)危險(xiǎn)存儲(chǔ)過(guò)程刪除與恢復(fù)方法
  • sqlserver 復(fù)制表 復(fù)制數(shù)據(jù)庫(kù)存儲(chǔ)過(guò)程的方法
  • 一個(gè)查看MSSQLServer數(shù)據(jù)庫(kù)空間使用情況的存儲(chǔ)過(guò)程 SpaceUsed
  • SQL SERVER數(shù)據(jù)庫(kù)開(kāi)發(fā)之存儲(chǔ)過(guò)程應(yīng)用

標(biāo)簽:煙臺(tái) 珠海 北海 東營(yíng) 南昌 石家莊 咸寧 晉中

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《SQL Server數(shù)據(jù)庫(kù)中的存儲(chǔ)過(guò)程介紹》,本文關(guān)鍵詞  SQL,Server,數(shù)據(jù)庫(kù),中的,存儲(chǔ),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《SQL Server數(shù)據(jù)庫(kù)中的存儲(chǔ)過(guò)程介紹》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于SQL Server數(shù)據(jù)庫(kù)中的存儲(chǔ)過(guò)程介紹的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 缙云县| 三河市| 新闻| 荔浦县| 六枝特区| 同心县| 凭祥市| 南京市| 山东省| 大埔县| 鹤壁市| 方城县| 进贤县| 杭锦后旗| 长沙市| 祁门县| 林芝县| 交城县| 朝阳县| 伊金霍洛旗| 阿瓦提县| 玉环县| 商南县| 麦盖提县| 富源县| 建宁县| 沂南县| 肃北| 会泽县| 扬州市| 科尔| 滨海县| 桑植县| 塔城市| 莲花县| 沅陵县| 大厂| 崇文区| 临夏市| 长岛县| 锦州市|