儲存過程概念

2021-08-25 21:41:48 字數 2459 閱讀 3700

專題:資料庫儲存過程的專題----

儲存過程

sql語句執行的時候要先編譯,然後執行。儲存過程就是編譯好了的一些sql語句。應用程式需要用的時候直接呼叫就可以了,所以效率會高。

儲存過程介紹

儲存過程是由流控制和sql語句書寫的過程,這個過程經編譯和優化後儲存在資料庫伺服器中,應用程式使用時只要呼叫即可。在oracle中,若干個有聯絡的過程可以組合在一起構成程式包。

使用儲存過程有以下的優點:

* 儲存過程的能力大大增強了sql語言的功能和靈活性。儲存過程可以用流控制語句編寫,有很強的靈活性,可以完成複雜的判斷和較複雜的 運算。

* 可保證資料的安全性和完整性。

# 通過儲存過程可以使沒有許可權的使用者在控制之下間接地訪問資料庫,從而保證資料的安全。

# 通過儲存過程可以使相關的動作在一起發生,從而可以維護資料庫的完整性。

* 再執行儲存過程前,資料庫已對其進行了語法和句法分析,並給出了優化執行方案。這種已經編譯好的過程可極大地改善sql語句的效能。 由於執行sql語句的大部分工作已經完成,所以儲存過程能以極快的速度執行。

* 可以降低網路的通訊量。

* 使體現企業規則的運算程式放入資料庫伺服器中,以便:

# 集中控制。

# 當企業規則發生變化時在伺服器中改變儲存過程即可,無須修改任何應用程式。企業規則的特點是要經常變化,如果把體現企業規則的運算程式放入應用程式中,則 當企業規則發生變化時,就需要修改應用程式工作量非常之大(修改、發行和安裝應用程式)。如果把體現企業規則的 運算放入儲存過程中,則當企業規則發生變化時,只要修改儲存過程就可以了,應用程式無須任何變化。

資料庫儲存過程的實質就是部署在資料庫端的一組定義**以及sql。

利用sql的語言可以編寫對於資料庫訪問的儲存過程,其語法如下:

create proc[edure] procedure_name [;number] 

[ ][varying] [= default] [output]

] [,...n]

[with  ]

[for replication]

as sql_statement [...n]

[ ]內的內容是可選項,而()內的內容是必選項,

例: 若使用者想建立乙個刪除表tmp中的記錄的儲存過程select_delete可寫為:

create proc select_del as 

delete tmp

例:使用者想查詢tmp表中某年的資料的儲存過程

create proc select_query @year int as 

select * from tmp where year=@year

在這裡@year是儲存過程的引數

例:該儲存過程是從某結點n開始找到最上層的父親結點,這種經常用到的過程可以由儲存過程來擔當,在網頁中重複使用達到共享。

空:表示該結點為頂層結點

fjdid(父結點編號) 

結點n 非空:表示該結點的父親結點號

dwmc(單位名稱)

create proc search_dwmc @dwidold int,@dwmcresult varchar(100) output 

as declare @stop int

declare @result varchar(80)

declare @dwmc varchar(80)

declare @dwid int

set nocount on

set @stop=1

set @dwmc=""

select @dwmc=dwmc,@dwid=convert(int,fjdid) from jtdw where id=@dwidold 

set @result=rtrim(@dwmc)

if @dwid=0 

set @stop=0

while (@stop=1) and (@dwid<>0)

begin

set @dwidold=@dwid

select @dwmc=dwmc,@dwid=convert(int,fjdid) from jtdw where id=@dwidold

if @@rowcount=0 

set @dwmc=""

else

set @result=@dwmc+@result

if (@dwid=0) or (@@rowcount=0) 

set @stop=0

else

continue

end

set @dwmcresult=rtrim(@result)

使用exec pro-name [pram1 pram2.....]

儲存過程概念

剛畢業找工作時,資料庫方面被問的較多的乙個問題,現在才對這個概念有真正的接觸,學習小結一下。將常用的或很複雜的工作,預先用sql語句寫好並用乙個指定的名稱儲存起來,那麼以後要叫資料庫提供與已定義好的儲存過程的功能相同的服務時,只需呼叫execute,即可自動完成命令。使用儲存過程而非sql語句的原因...

儲存過程概念

1 儲存過程的概念 儲存過程是一組為了完成特定功能的sql語句集,經編譯後儲存在資料庫中,使用者通過指定儲存過程的名字並給出引數來執行它,通常情況下,將常用或很複雜的語句編寫成儲存過程。儲存過程 stored procedure 是在大型資料庫系統中,一組為了完成特定功能的sql語句集,儲存在資料庫...

儲存過程的概念

儲存過程是由流控制和sql語句書寫的過程,這個過程經過編譯和優化,後儲存在資料庫伺服器中,使用時只要呼叫即可。在oracle中若干個有聯絡的儲存的過程可以組合在一起構成乙個程式包。儲存過程有以下的優點 儲存過程的能力大大增強了sql語言的功能和靈活性,儲存過程可以用流控制語句進行編寫,有很強的靈活性...