1. 程式人生 > >MySQL儲存過程詳解 mysql 儲存過程,if,while常用語句

MySQL儲存過程詳解 mysql 儲存過程,if,while常用語句

mysql儲存過程詳解

1. 儲存過程簡介

我們常用的操作資料庫語言SQL語句在執行的時候需要要先編譯,然後執行,而儲存過程(Stored Procedure)是一組為了完成特定功能的SQL語句集,經編譯後儲存在資料庫中,使用者通過指定儲存過程的名字並給定引數(如果該儲存過程帶有引數)來呼叫執行它。

一個儲存過程是一個可程式設計的函式,它在資料庫中建立並儲存。它可以有SQL語句和一些特殊的控制結構組成。當希望在不同的應用程式或平臺上執行相同的函式,或者封裝特定功能時,儲存過程是非常有用的。資料庫中的儲存過程可以看做是對程式設計中面向物件方法的模擬。它允許控制資料的訪問方式。

儲存過程通常有以下優點:

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

(2).儲存過程允許標準組件是程式設計。儲存過程被建立後,可以在程式中被多次呼叫,而不必重新編寫該儲存過程的SQL語句。而且資料庫專業人員可以隨時對儲存過程進行修改,對應用程式原始碼毫無影響。

(3).儲存過程能實現較快的執行速度。如果某一操作包含大量的Transaction-SQL程式碼或分別被多次執行,那麼儲存過程要比批處理的執行速度快很多。因為儲存過程是預編譯的。在首次執行一個儲存過程時查詢,優化器對其進行分析優化,並且給出最終被儲存在系統表中的執行計劃。而批處理的

Transaction-SQL語句在每次執行時都要進行編譯和優化,速度相對要慢一些。

(4).儲存過程能過減少網路流量。針對同一個資料庫物件的操作(如查詢、修改),如果這一操作所涉及的Transaction-SQL語句被組織程儲存過程,那麼當在客戶計算機上呼叫該儲存過程時,網路中傳送的只是該呼叫語句,從而大大增加了網路流量並降低了網路負載。

(5).儲存過程可被作為一種安全機制來充分利用。系統管理員通過執行某一儲存過程的許可權進行限制,能夠實現對相應的資料的訪問許可權的限制,避免了非授權使用者對資料的訪問,保證了資料的安全。

2. 關於MySQL的儲存過程

儲存過程是資料庫儲存的一個重要的功能,但是

MySQL5.0以前並不支援儲存過程,這使得MySQL在應用上大打折扣。好在MySQL 5.0終於開始已經支援儲存過程,這樣即可以大大提高資料庫的處理速度,同時也可以提高資料庫程式設計的靈活性。

3. MySQL儲存過程的建立

(1). 格式

MySQL儲存過程建立的格式:CREATE PROCEDURE 過程名 ([過程引數[,...]])
[
特性 ...] 過程體

這裡先舉個例子:
 

  1. mysql> DELIMITER //  
  2. mysql> CREATEPROCEDURE proc1(OUT int)  
  3.     -> BEGIN
  4.     -> SELECTCOUNT(*) INTO FROMuser;  
  5.     -> END
  6.     -> //  
  7. mysql> DELIMITER 
注:

1)這裡需要注意的是DELIMITER //DELIMITER ;兩句,DELIMITER是分割符的意思,因為MySQL預設以";"為分隔符,如果我們沒有宣告分割符,那麼編譯器會把儲存過程當成SQL語句進行處理,則儲存過程的編譯過程會報錯,所以要事先用DELIMITER關鍵字申明當前段分隔符,這樣MySQL才會將";"當做儲存過程中的程式碼,不會執行這些程式碼,用完了之後要把分隔符還原。

2)儲存過程根據需要可能會有輸入、輸出、輸入輸出引數,這裡有一個輸出引數s,型別是int型,如果有多個引數用","分割開。

3)過程體的開始與結束使用BEGINEND進行標識。

這樣,我們的一個MySQL儲存過程就完成了,是不是很容易呢?看不懂也沒關係,接下來,我們詳細的講解。

(2). 宣告分割符

其實,關於宣告分割符,上面的註解已經寫得很清楚,不需要多說,只是稍微要注意一點的是:如果是用MySQLAdministrator管理工具時,可以直接建立,不再需要宣告。

(3). 引數

MySQL儲存過程的引數用在儲存過程的定義,共有三種引數型別,IN,OUT,INOUT,形式如:

CREATE PROCEDURE([[IN |OUT |INOUT ] 引數名 資料類形...])

IN 輸入引數:表示該引數的值必須在呼叫儲存過程時指定,在儲存過程中修改該引數的值不能被返回,為預設值

OUT 輸出引數:該值可在儲存過程內部被改變,並可返回

INOUT 輸入輸出引數:呼叫時指定,並且可被改變和返回

. IN引數例子

建立:

  1. mysql DELIMITER //  
  2. mysql CREATEPROCEDURE demo_in_parameter(IN p_in int)  
  3. -> BEGIN
  4. -> SELECT p_in; 
  5. -> SET p_in=2; 
  6. -> SELECT p_in; 
  7. -> END
  8. -> //  
  9. mysql DELIMITER 


執行結果
:

  1. mysql SET @p_in=1;  
  2. mysql CALL demo_in_parameter(@p_in);  
  3. +------+ 
  4. p_in |  
  5. +------+ 
  6.    
  7. +------+ 
  8. +------+ 
  9. p_in |  
  10. +------+ 
  11.    
  12. +------+ 
  13. mysql> SELECT @p_in;  
  14. +-------+ 
  15. @p_in |  
  16. +-------+ 
  17.     |  
  18. +-------+ 


以上可以看出,
p_in雖然在儲存過程中被修改,但並不影響@p_id的值

.OUT引數例子

建立:

  1. mysql DELIMITER //  
  2. mysql CREATEPROCEDURE demo_out_parameter(OUT p_out int)  
  3. -> BEGIN
  4. -> SELECT p_out;  
  5. -> SET p_out=2;  
  6. -> SELECT p_out;  
  7. -> END;  
  8. -> //  
  9. mysql DELIMITER 

執行結果:

  1. mysql SET @p_out=1;  
  2. mysql CALL sp_demo_out_parameter(@p_out);  
  3. +-------+ 
  4. p_out 
  5. +-------+ 
  6. NULL  
  7. +-------+ 
  8. +-------+ 
  9. p_out |  
  10. +-------+ 
  11.     
  12. +-------+ 
  13. mysql> SELECT @p_out;  
  14. +-------+ 
  15. p_out |  
  16. +-------+ 
  17.     |  
  18. +-------+ 

. INOUT引數例子

建立:

  1. mysql DELIMITER //  
  2. mysql CREATEPROCEDURE demo_inout_parameter(INOUT p_inout int)  
  3. -> BEGIN
  4. -> SELECT p_inout;  
  5. -> SET p_inout=2;  
  6. -> SELECT p_inout; 
  7. -> END;  
  8. -> // 
  9. mysql DELIMITER 
執行結果:
  1. mysql > SET @p_inout=1;  
  2. mysql > CALL demo_inout_parameter(@p_inout) ;  
  3. +---------+  
  4. p_inout |  
  5. +---------+  
  6.       |  
  7. +---------+  
  8. +---------+  
  9. p_inout 
  10. +---------+  
  11.       |  
  12. +---------+  
  13. mysql > SELECT @p_inout;  
  14. +----------+  
  15. @p_inout 
  16. +----------+  
  17.        |  
  18. +----------+ 

(4). 變數

. 變數定義

DECLARE variable_name [,variable_name...] datatype [DEFAULT value];

其中,datatypeMySQL的資料型別,如:int, float, date, varchar(length)

例如:

  1. DECLARE l_int int unsigned default 4000000;  
  2. DECLARE l_numeric number(8,2) 

    相關推薦

    MySQL儲存過程 mysql 儲存過程,if,while常用語句

    mysql儲存過程詳解 1. 儲存過程簡介 我們常用的操作資料庫語言SQL語句在執行的時候需要要先編譯,然後執行,而儲存過程(Stored Procedure)是一組為了完成特定功能的SQL語句集,經編譯後儲存在資料庫中,使用者通過指定

    MySQL儲存過程 mysql 儲存過程--完全可以當手冊使用呢~

    ADDTIME (date2 ,time_interval ) //將time_interval加到date2 CONVERT_TZ (datetime2 ,fromTZ ,toTZ ) //轉換時區 CURRENT_DATE ( ) //當前日期 CURRENT_TIME ( ) //當前時間 CU

    mysql儲存引擎InnoDB插入資料的過程

    https://blog.csdn.net/tangkund3218/article/details/47361705 mysql是目前市面上應用非常廣泛的關係型資料庫. 當插入,更新,刪除等sql語句執行後,mysql為何總能高效,快速的執行,而且不管是斷電,mysql程序崩潰,還是一些其

    MySQL檢視和儲存過程

    一 mysql檢視 1 檢視的目的: 讓同一個資料庫被訪問時,對於不同的登入帳號,顯示不同的資料資訊 2 檢視的優點: 1)資料獨立: 一旦檢視結構確定,可以遮蔽表結構對使用者的影響 2)安全: 使用者只能看到檢視中的資料 3)簡單: 使用者不需要關心檢視中的資料如何查詢獲得,檢視中的資

    撩課-Mysql第19部分儲存過程

    學習地址: 撩課-JavaWeb系列1之基礎語法-前端基礎 撩課-JavaWeb系列2之XML 撩課-JavaWeb系列3之MySQL 撩課-JavaWeb系列4之JDBC 撩課-JavaWeb系列5之web伺服器-idea 什麼是儲存過程 一組可程式設計的函式, 是為了完成特

    Mysql觸發器、檢視、儲存過程(例項)

    /*觸發器trigger*/觸發器的概念:監視某種情況並出發某種操作例如:一個電子商城商品表goods簡稱g:主鍵   商品名    庫存    1      電腦      282      手錶      120訂單表o:訂單主鍵    訂單外來鍵    購買數量1   

    mysql儲存過程

    mysql> CREATE PROCEDURE p1() SET @last_procedure='p1'; mysql> CREATE PROCEDURE p2() SELECT CONCAT('Last procedure was ',@last_proc); mysql&g

    MySQL資料庫-儲存過程

    儲存過程簡單來說,就是為以後的使用而儲存的一條或多條MySQL語句的集合。可將其視為批件,雖然它們的作用不僅限於批處理。在我看來, 儲存過程就是有業務邏輯和流程的集合, 可以在儲存過程中建立表,更新資料, 刪除等等。 MySQL基礎教程之儲存過程 儲存過程簡單來說,就

    Mysql加鎖過程

    插入記錄 控制 uniq null 詳細 server 讀者 index 理論知識 1、背景   MySQL/InnoDB的加鎖分析,一直是一個比較困難的話題。我在工作過程中,經常會有同事咨詢這方面的問題。同時,微博上也經常會收到MySQL鎖相關的私信,讓我幫助解決一些死

    Mysql加鎖過程(4)-select for update/lock in share mode 對事務並發性影響

    per inno targe 允許 evel transacti 修改 not null warn select for update/lock in share mode 對事務並發性影響 事務並發性理解 事務並發性,粗略的理解就是單位時間內能夠執行的事務數量,常見的單

    Mysql加鎖過程(9)-innodb下的記錄鎖,間隙鎖,next-key鎖

    ans 唯一索引 crazy cimage -h insert tran 存在 gin Mysql加鎖過程詳解(1)-基本知識 Mysql加鎖過程詳解(2)-關於mysql 幻讀理解 Mysql加鎖過程詳解(3)-關於mysql 幻讀理解 Mysql加鎖過程詳解(4)-

    MySQL對資料庫資料進行復制的基本過程

    MySQL對資料庫資料進行復制的基本過程詳解 這篇文章主要介紹了MySQL對資料庫資料進行復制的基本過程,解讀了Slave的一些相關配置,需要的朋友可以參考下 複製 複製是從一個MySQL伺服器(master)將資料拷貝到另外一臺或多臺MySQL伺服器(slaves)的過程.複製是非同步進行的--sla

    資料庫儲存過程 儲存過程

    轉自張龍豪原文儲存過程詳解 儲存過程(Procedure)可以說是一個記錄集吧,它是由一些T-SQL語句組成的程式碼塊,這些T-SQL語句程式碼像一個方法一樣實現一些功能(對單表或多表的增刪改查),然後再給這個程式碼塊取一個名字,在用到這個功能的時候呼叫他就行了。 儲存過程的好處:1.由於資料庫執行動作時

    mongo 儲存過程

    儲存過程 關係型資料庫的儲存過程描述為: 一組為了完成特定功能的SQL 語句集,經編譯後儲存在資料庫中,使用者通過指定儲存過程的名字並給出引數(如果該儲存過程帶有引數)來執行它 。 MongoDB 為很多問題提供了一系列的解決方案,針對於其它資料庫的特性,它仍然毫不示 弱,表現的非比尋常。MongoDB

    Java呼叫SQL Server的儲存過程

                    本文較長,包含了如下幾部分                    1使用不帶引數的儲存過程     使用 JDBC 驅動程式呼叫不帶引數的儲存過程時,必須使用 call SQL 轉義序列。不帶引數的 call 轉義序列的語法如下所示: {call procedure-name}

    ORACLE儲存、遊標過程

    ORACLE儲存過程詳解 1、定義 所謂儲存過程(Stored Procedure),就是一組用於完成特定資料庫功能的SQL語句集,該SQL語句集經過編譯後儲存在資料庫系統中。在使用時候,使用者通過指定已經定義的儲存過程名字並給出相應的儲存過程引數來呼叫並執行它,從而完成

    MSSQL儲存過程

    用TSQL語句編寫儲存過程一、變數和引數           DECLARE 語句通過以下操作初始化 Transact-SQL 變數:           指定名稱。名稱的第一個字元必須為一個 @。           指定系統提供的或使用者定義的資料型別和長度。對於數值變數還指定精度和小數位數。對於 XML

    Oracle儲存過程(一)

    儲存過程建立語法: create [or replace] procedure 儲存過程名(param1 in type,param2 out type) as 變數1 型別(值範圍); 變數2 型別(值範圍); Begin Select

    儲存過程

    public partial class ProcedureTest : System.Web.UI.Page { public static string conn = ConfigurationManager.ConnectionStrings["StuRelationDBC

    資料庫儲存過程

    儲存過程的優缺點   ◆優點:   執行速度更快。儲存過程只在創造時進行編譯,而一般SQL語句每執行一次就編譯一次,所以使用儲存過程執行速度更快。   儲存過程用於處理複雜的操作時,程式的可讀性更強、網路的負擔更小。   使用儲存過程封裝事務效能更佳。   能有效的放注入