sql語句需要先編譯然後執行,而儲存過程(stored procedure)是一組為了完成特定功能的sql語句集,經編譯後儲存在資料庫中,使用者通過指定儲存過程的名字並給定引數(如果該儲存過程帶有引數)來呼叫執行它。
儲存過程是可程式設計的函式,在資料庫中建立並儲存,可以由sql語句和控制結構組成。當想要在不同的應用程式或平台上執行相同的函式,或者封裝特定功能時,儲存過程是非常有用的。資料庫中的儲存過程可以看做是對程式設計中物件導向方法的模擬,它允許控制資料的訪問方式。
儲存過程的優點:
(1).增強sql語言的功能和靈活性:儲存過程可以用控制語句編寫,有很強的靈活性,可以完成複雜的判斷和較複雜的運算。
(2).標準元件式程式設計:儲存過程被建立後,可以在程式中被多次呼叫,而不必重新編寫該儲存過程的sql語句。而且資料庫專業人員可以隨時對儲存過程進行修改,對應用程式源**毫無影響。
(3).較快的執行速度:如果某一操作包含大量的transaction-sql**或分別被多次執行,那麼儲存過程要比批處理的執行速度快很多。因為儲存過程是預編譯的。在首次執行乙個儲存過程時查詢,優化器對其進行分析優化,並且給出最終被儲存在系統表中的執行計畫。而批處理的transaction-sql語句在每次執行時都要進行編譯和優化,速度相對要慢一些。
(4).減少網路流量:針對同乙個資料庫物件的操作(如查詢、修改),如果這一操作所涉及的transaction-sql語句被組織進儲存過程,那麼當在客戶計算機上呼叫該儲存過程時,網路中傳送的只是該呼叫語句,從而大大減少網路流量並降低了網路負載。
(5).作為一種安全機制來充分利用:通過對執行某一儲存過程的許可權進行限制,能夠實現對相應的資料的訪問許可權的限制,避免了非授權使用者對資料的訪問,保證了資料的安全。
mysql的儲存過程
儲存過程是資料庫的乙個重要的功能,mysql 5.0以前並不支援儲存過程,這使得mysql在應用上大打折扣。好在mysql 5.0開始支援儲存過程,這樣即可以大大提高資料庫的處理速度,同時也可以提高資料庫程式設計的靈活性。
mysql儲存過程的建立
語法create procedure 過程名([
[in|out|inout] 引數名 資料型別,[in|out|inout] 引數名 資料型別,… ]) [特性 ...] 過程體
delimiter //
create definer=`root`@`localhost` procedure `test`.`addresult5`(in num int, in m int, in n int)
reads sql data
comment '測試5'
begin
if num is null then
select * from tb_score where score>m and score<=n;
elseif m is null then
select * from tb_score where userid=num and score<=n;
elseif n is null then
select * from tb_score where userid=num and score>m;
else
# 查詢某部門的成績大於m,小於n的人
select * from tb_score where userid=num and score>m and score<=n;
end if;
end//
delimiter ;
分隔符mysql預設以";"為分隔符,如果上面的建立語句直接在mysql互動視窗執行建立的話,若沒有宣告分隔符,則編譯器會把儲存過程(上面這條語句)當成sql語句進行處理,因此編譯過程會報錯,所以要事先用「delimiter //」宣告當前段分隔符,讓編譯器把兩個"//"之間的內容當做儲存過程的**,不會執行這些**。「delimiter ;」的意為把分隔符還原。
引數儲存過程根據需要可能會有輸入、輸出、輸入輸出引數,如果有多個引數用","分割開。mysql儲存過程的引數用在儲存過程的定義,共有三種引數型別 輸入為in,輸出為out,既作為輸入又作為輸出為inout
in引數的值必須在呼叫儲存過程時指定,在儲存過程中修改該引數的值不能被返回,為預設值。
out 該值可在儲存過程內部被改變,並可返回。
inout 呼叫時指定,並且可被改變和返回。
過程體過程體的開始與結束使用begin與end進行標識。
例項:無參:
create definer=`root`@`localhost` procedure `test`.`addresult0`()
comment '測試0'
begin
declare i int;
declare sum int;
declare n int;
set i =1;
set n =10;
set sum =0;
while i<=n do
set sum = sum+i;
set i=i+1;
end while;
select
sum;
end
呼叫:
乙個引數:
create definer=`root`@`localhost` procedure `test`.`addresult1`(in n int)
comment '測試1'
begin
declare i int;
declare sum int;
set i =1;
set sum =0;
while i<=n do
set sum = sum+i;
set i=i+1;
end while;
select
sum;
end
呼叫:
有變數接收返回值:
create definer=`root`@`localhost` procedure `test`.`addresult2`(out sum int)
reads sql data
comment '測試2'
begin
declare i int;
declare n int;
declare sum int;
set i =1;
set sum =0;
set n = 10; # 預設值
while i<=n do
set sum = sum+i;
set i=i+1;
end while;
select
sum;
end
呼叫:
set @a=0;--設定接收結果的變數
多個引數以及if else 控制語句:
create definer=`root`@`localhost` procedure `test`.`addresult4`(in num int, in m int, in n int)
reads sql data
comment '測試4'
begin
if num is null then
select * from tb_score where score>m and score<=n;
elseif m is null then
select * from tb_score where userid=num and score<=n;
elseif n is null then
select * from tb_score where userid=num and score>m;
else
# 查詢某部門的成績大於m,小於n的人
select * from tb_score where userid=num and score>m and score<=n;
end if;
end
呼叫:
儲存過程系列之儲存過程sql查詢儲存過程的使用
1.查詢某個表被哪些儲存過程 以下簡稱 sp 使用到 select distinct object name id from syscomments where id in select object id from sys.objects where type p and text like ta...
儲存過程系列之儲存過程sql查詢儲存過程的使用
1.查詢某個表被哪些儲存過程 以下簡稱 sp 使用到 select distinct object name id from syscomments where id in select object id from sys.objects where type p and text like ta...
Oracle儲存過程呼叫儲存過程
oracle儲存過程呼叫有返回結果集的儲存過程一般用光標的方式,宣告乙個游標,把結果集放到游標裡面,然後迴圈游標 declare newcs sys refcursor cs1 number cs2 number cstype table rowtype table列的個數和newcs返回的個數一樣...