儲存過程sql
Ⅰ oracle中的存儲過程,有什麼作用,以及怎麼在代碼中使用
定義:存儲過程(Stored Procere )是一組為了完成特定功能的sql 語句
集,經編譯後存儲在資料庫中。用戶通過指定存儲過程的名字並給出參數
(如果該存儲過程帶有參數)來執行它。存儲過程是資料庫中的一個重要
對象,任何一個設計良好的資料庫應用程序都應該用到存儲過程。
存儲過程是由流控制和SQL 語句書寫的過程,這個過程經編譯和優化後
存儲在資料庫伺服器中,應用程序使用時只要調用即可。在ORACLE 中,
若干個有聯系的過程可以組合在一起構成程序包。
優點:存儲過程只在創造時進行編譯,以後每次執行存儲過程都不需再重新編譯,而一般SQL語句每執行一次就編譯一次,所以使用存儲過程可提高資料庫執行速度。
2.當對資料庫進行復雜操作時(如對多個表進行Update、Insert、Query、Delete時),可將此復雜操作用存儲過程封裝起來與資料庫提供的事務處理結合一起使用。
3.存儲過程可以重復使用,可減少資料庫開發人員的工作量。
4.安全性高,可設定只有某用戶才具有對指定存儲過程的使用權。
proc = connection.prepareCall("{ call SIM_MEDICARE.P_Isinblacklist(?,?,?,?,?) }");
proc.setString(1, 「」);設置傳入參數
proc.registerOutParameter(4, Types.VARCHAR);注冊傳出參數
proc.execute();執行過程
proc.getString(4)獲取結果
Ⅱ SQL 中存儲過程怎麼使用
一、簡單的儲存過程:
1、創建一個存儲過程
create procere GetUsers()
begin
select * from user;
end;12345
2、調用存儲過程
call GetUsers();12
3、刪除存儲過程
drop procere if exists GetUsers;
二、帶參數的存儲過程
1、MySql 支持 IN (傳遞給存儲過程) , OUT (從存儲過程傳出) 和 INOUT (對存儲過程傳入和傳出) 類型的參數 , 存儲過程的代碼位於 BEGIN 和 END 語句內 , 它們是一系列 SQL 語句 , 用來檢索值 , 然後保存到相應的變數 (通過指定INTO關鍵字) ;
2、下面的存儲過程接受三個參數 , 分別用於獲取用戶表的最小 , 平均 , 最大分數 , 每個參數必須具有指定的類型 , 這里使用十進制值(decimal(8,2)) , 關鍵字 OUT 指出相應的參數用來從存儲過程傳出
create procere GetScores(
out minScore decimal(8,2),
out avgScore decimal(8,2),
out maxScore decimal(8,2)
)
begin
select min(score) into minScore from user;
select avg(score) into avgScore from user;
select max(score) into maxScore from user;
end;1234567891011
3、調用此存儲過程 , 必須指定3個變數名(所有 MySql 變數都必須以@開始) , 如下所示 :
call GetScores(@minScore, @avgScore, @maxScore);12
4、該調用並沒有任何輸出 , 只是把調用的結果賦給了調用時傳入的變數@minScore, @avgScore, @maxScore, 然後即可調用顯示該變數的值 :
select @minScore, @avgScore, @maxScore;
5、使用 IN 參數 , 輸入一個用戶 id , 返回該用戶的名字 :
create procere GetNameByID(
in userID int,
out userName varchar(200)
)
begin
select name from user
where id = userID
into userName;
end;12345678910
6、調用存儲過程 :
call GetNameByID(1, @userName);
select @userName;123
Ⅲ SQL SERVER 中存儲過程、視圖、索引是什麼概念
儲存過程:簡單說就是SQL代碼的集合,和C語言里的函數類似,
儲存過程把SQL語句寫在一起,
調用儲存過程時
SQLserver執行 這些語句。
它有參數,有返回值。
優點:
1.模塊化設計
像其他程序語言的函數一樣,單獨出來,可以調用它n次,
並且可以獨立於源代碼,單獨修改儲存過程。
2.更快執行如果執行大量SQL代碼或重復執行,儲存過程比SQL批代碼執行要快。
3.減少網路流量
一條SQL語句就可以執行上千條SQL代碼,肯定視圖:顧名思意,可以看的圖形。
用圖形來表示資料庫中表,或表之間的關系
是虛擬表,是來自其一個表,或多個表的行或列 的子集。
臨時表是暫時存在的,而視圖是以文件存儲的,只要不人為刪除,
是永久存儲的,所以視圖不是臨時表。
索引:舉一個列子,你在學校要找一年級三班教室,但是你不知具體位置,
你只能按照順序,一間教室一間教室的找,
但如果,你看學校地圖(假設的),上面寫有一年級三班教室在XX單元XX樓左邊XX間,那你就可以直接到教室去了,
這里地圖就相當於索引,指明具體地址,使查詢更加的快捷。
SQL里就是這樣,要查詢某個數據,根據索引查找,比一個一個挨著查,更加的快捷。
Ⅳ sql存儲過程的優點
1.存儲過程可以使得程序執行效率更高、安全性更好,因為過程建立之後
已經編譯並且儲存到資料庫,直接寫sql就需要先分析再執行因此過程效率更高,直接寫sql語句會帶來安全性問題,如:sql注入
2.建立過程不會很耗系統資源,因為過程只是在調用才執行。
3.如果我表book更新了
存儲過程是不是要重新遍歷一下表?不會,如果有需要根據book表更新而更新可考慮建立觸發器在特定條件觸發,如:insert,update,delete語法如下:
create
trigger
tr_book
on
book
for
insert,update,delete
as
begin
...
end
補充回答:數據量越大執行過程越長.如是幾十條幾或幾K可能看不出效果如果是上10W或者過100W你就會發現速度(查詢、更新)會慢很多,,隨著數據量增大你的存儲過程執行時間會更長是一定的
Ⅳ 關於SQL的臨時表、自定義函數、儲存過程的問題
如果你有編程基礎的話
那麼自定義函數和存儲過程的區別,就是程序裡面函數與過程的區別,函數只是為了實現某個功能,而過程是為了實現某個流程。
至於使用的時間
這個跟你的實際需求有關系的,一般系統帶的函數就能滿足需求。
存儲過程這個看你項目的訪問量,訪問量小的話
如果是快速開發不會用到存儲過程
直接在程序裡面寫SQL語句就OK。如果訪問量大,那麼必須使用存儲過程。
臨時表的好處是它可以是只對某個用戶的表,而且不具有實際意義,並且可以定義自動銷毀的臨時表。跟視圖在某種情況下有相同之處。
臨時表的試用時間也是跟你的需求有關系的。
創建語句差不多
都是T-SQL語句。
最後一個問題你得搜索一下才知道,一般情況下定義的臨時表都是自動銷毀的,使用完畢會drop掉(節省資源,如果是#開頭的臨時表
系統會自動在使用完畢後銷毀掉。)