欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SQL Server數(shù)據(jù)庫中的存儲過程介紹

 更新時間:2015年01月27日 09:03:05   投稿:junjie  
這篇文章主要介紹了SQL Server數(shù)據(jù)庫中的存儲過程介紹,本文講解了什么是存儲過程、存儲過程語法、存儲過程的一些使用實例等內(nèi)容,需要的朋友可以參考下

什么是存儲過程

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

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

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

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

1.可保證數(shù)據(jù)的安全性和完整性。
2.通過存儲過程可以使沒有權(quán)限的用戶在控制之下間接地存取數(shù)據(jù)庫,從而保證數(shù)據(jù)的安全。
3.通過存儲過程可以使相關(guān)的動作在一起發(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ù)庫幫助,查詢數(shù)據(jù)庫信息
exec sp_helpdb master;
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ù)要加上output
as
begin
select @Name=Name from dbo.Office_Info where Id=@Id --(sql語句)
end
declare @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
begin
if(select Name from dbo.Office_Info where Id=@Id)=null --(sql語句)
begin
return -1
end
else
begin
return 1
end
end

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

相關(guān)文章

  • sql中的char與varchar有什么區(qū)別

    sql中的char與varchar有什么區(qū)別

    varchar使用起來較為靈活,節(jié)省了一定的空間,但是它在判斷位數(shù)時也耗費了時間,從整個系統(tǒng)的性能角度來說,char數(shù)據(jù)類型處理的速度更快,有時甚至可以超出varchar處理速度的很多倍,本文給大家介紹
    sql中的char與varchar有什么區(qū)別,一起看看吧
    2023-10-10
  • SQL Server游標的使用/關(guān)閉/釋放/優(yōu)化小結(jié)

    SQL Server游標的使用/關(guān)閉/釋放/優(yōu)化小結(jié)

    游標打破了這一查詢的思考是面向集合的規(guī)則,游標使得我們思考方式變?yōu)橹鹦羞M行,接下來為大家介紹下游標的使用感興趣的朋友可以參考下哈,希望可以幫助到你
    2013-03-03
  • Android實現(xiàn)矩形區(qū)域截屏的方法

    Android實現(xiàn)矩形區(qū)域截屏的方法

    對屏幕進行截屏并裁剪有兩種方式:早截圖和晚截圖,對于早截圖和晚截圖的概念大家通過本文詳解學習。本文重點給大家介紹android實現(xiàn)矩形區(qū)域截屏的方法,需要的朋友參考下
    2017-01-01
  • SQL查詢排名函數(shù)實例

    SQL查詢排名函數(shù)實例

    本文主要講解SQL查詢排名函數(shù)實例,比較實用,希望能給大家做一個參考。
    2016-06-06
  • SQL?Server?2008?R2完美卸載教程(親測有用)

    SQL?Server?2008?R2完美卸載教程(親測有用)

    SQL Server 2008 R2是一款非常強大的數(shù)據(jù)庫管理系統(tǒng),但在某些情況下可能需要卸載它,下面這篇文章主要給大家介紹了關(guān)于SQL?Server?2008?R2完美卸載的相關(guān)資料,需要的朋友可以參考下
    2023-11-11
  • EXEC(EXECUTE)函數(shù)訪問INSERTED或DELETED的內(nèi)部臨時觸發(fā)表

    EXEC(EXECUTE)函數(shù)訪問INSERTED或DELETED的內(nèi)部臨時觸發(fā)表

    近段時間,MS SQL方面,一直需要開發(fā)動態(tài)方面的存儲過程或是觸發(fā)器以及表函數(shù)。因為程序設計一開始就是讓用戶動態(tài)添或是刪除一個表的字段,然而這個表的相關(guān)存儲過程或是觸發(fā)器以及為報表準備的表函數(shù)也會隨之這個表的字段變化而變化
    2012-01-01
  • 如何恢復數(shù)據(jù)庫的賬號 登錄名/用戶名等

    如何恢復數(shù)據(jù)庫的賬號 登錄名/用戶名等

    當重裝數(shù)系統(tǒng)/數(shù)據(jù)庫之后,如何恢復數(shù)據(jù)庫的賬號 登錄名/用戶名 孤立用戶 縮小ldf日志文件 修改sqlserver2000端口
    2013-08-08
  • uniqueidentifier轉(zhuǎn)換成varchar數(shù)據(jù)類型的sql語句

    uniqueidentifier轉(zhuǎn)換成varchar數(shù)據(jù)類型的sql語句

    uniqueidentifier轉(zhuǎn)換成varchar數(shù)據(jù)類型的sql語句,需要的朋友可以參考下。
    2011-09-09
  • Sql Server中清空所有數(shù)據(jù)表中的記錄

    Sql Server中清空所有數(shù)據(jù)表中的記錄

    我這里介紹的是刪除數(shù)據(jù)庫的所有數(shù)據(jù),因為數(shù)據(jù)之間可能形成相互約束關(guān)系,刪除操作可能陷入死循環(huán),二是這里使用了微軟未正式公開的sp_MSForEachTable存儲過程
    2013-10-10
  • sql server通過pivot對數(shù)據(jù)進行行列轉(zhuǎn)換的方法

    sql server通過pivot對數(shù)據(jù)進行行列轉(zhuǎn)換的方法

    這篇文章主要介紹了sql server通過pivot對數(shù)據(jù)進行行列轉(zhuǎn)換的方法,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-05-05

最新評論