mysql存儲過程中的異常處理

来源:http://www.cnblogs.com/kungfupanda/archive/2016/09/15/5874229.html
-Advertisement-
Play Games

http://www.cnblogs.com/cookiehu/p/4994278.html 定義異常捕獲類型及處理方法: 這裡面需要註意幾點: a、condition_value [,condition_value],這個的話說明可以包括多種情況(方括弧表示可選的),也就是一個handler可以定 ...


http://www.cnblogs.com/cookiehu/p/4994278.html

定義異常捕獲類型及處理方法:

複製代碼
    DECLARE handler_action HANDLER  
        FOR condition_value [, condition_value] ...  
        statement  
      
    handler_action:  
        CONTINUE  
      | EXIT  
      | UNDO  
      
    condition_value:  
        mysql_error_code  
      | SQLSTATE [VALUE] sqlstate_value  
      | condition_name  
      | SQLWARNING  
      | NOT FOUND  
      | SQLEXCEPTION  
複製代碼

這裡面需要註意幾點:

  a、condition_value [,condition_value],這個的話說明可以包括多種情況(方括弧表示可選的),也就是一個handler可以定義成針對多種情況進行相應的 操作;另外condition_value可以包括的值有上面列出來的6種:

                1、mysql_error_code,這個表示mysql的錯誤代碼,錯誤代碼是一個數字,完成是由mysql自己定義的,這個值可以參考mysql資料庫錯誤代碼及信息

                2、SQLSTATE [VALUE] sqlstate_value,這個同錯誤代碼類似形成一一對應的關係,它是一個5個字元組成的字元串,關鍵的地方是它從ANSI SQL和ODBC這些標準中引用過來的,因此更加標準化,而不像上面的error_code完全是mysql自己定義給自己用的,這個和第一個類似也可以 參考mysql資料庫錯誤代碼及信息

                3、condtion_name,這個是條件名稱,它使用DECLARE...CONDITION語句來定義,這個後面我們會介紹如何定義自己的condition_name。

                4、SQLWARNING,表示SQLTATE中的字元串以‘01’起始的那些錯誤,比如Error: 1311 SQLSTATE: 01000 (ER_SP_UNINIT_VAR)

                5、NOT FOUND,表示SQLTATE中的字元串以‘02’起始的那些錯誤,比如Error: 1329 SQLSTATE: 02000 (ER_SP_FETCH_NO_DATA)

                6、SQLEXCEPTION,表示SQLSTATE中的字元串不是以'00'、'01'、'02' 起始的那些錯誤,這裡'00'起始的SQLSTATE其實表示的是成功執行而不是錯誤,另外兩個就是上面的4和5的兩種情況。

上面的6種情況其實可以分為兩類:

      一類就是比較明確的處理,就是對指定的錯誤情況進行處理,包括1、2、3這三種方式;

      另一類是對對應類型的錯誤的 處理,就是對某一群錯誤的處理,包括4、5、6這三種方式。這個是介紹了condition_value。另外還要註意的一個內容是MySQL在預設情況 下(也就是我們沒有定義處理錯誤的方法-handler)自己的錯誤處理機制:1、對於SQLWARNING和NOT FOUND的處理方法就是無視錯誤繼續執行,所以在游標的例子裡面如果我們沒有對repeat的條件判斷的那個值做個no_more_products=1的handler來處理,那麼迴圈就會一直下去。2、對於SQLEXCEPTION的話,其預設的處理方法是在出現錯誤的地方就終止掉了。

      b、statement,這個比較簡單就是當出現某種條件/錯誤時,我們要執行的語句,可以是簡單的如 SET  var = value這樣的簡單的語句,也可以是複雜的多行的語句,多行的話可以使用BEGIN  .....  END這裡把語句包括在裡面(這個好比delphi裡面的情況,註意到我們的存儲過程也是多行的,所以也要BEGIN .... END)。

      c、handler_action,這個表示當執行完上面的statement後,希望執行怎樣的動作,這裡包括CONTINUE、EXIT、UNDO, 表示繼續、退出、撤銷(暫時不支持)。這邊就是兩種動作,其實這兩種動作在上面也說過了,CONTINUE就是一個是SQLWARNING和NOT FOUND的預設處理方法,而EXIT就是SQLEXCEPTION的預設處理方法。

 

另:

condition_name:命名條件

MySQL error code或者SQLSTATE code的可讀性太差,所以引入了命名條件:

語法:

    DECLARE condition_name CONDITION FOR condition_value  
      
    condition_value:  
        SQLSTATE [VALUE] sqlstate_value  
      | mysql_error_code  

使用:

複製代碼
    # original  
    DECLARE CONTINUE HANDLER FOR 1216 MySQL_statements;  
      
    # changed  
    DECLARE foreign_key_error CONDITION FOR 1216;  
    DECLARE CONTINUE HANDLER FOR foreign_key_error MySQL_statements;  
複製代碼

示例:

複製代碼
    CREATE PROCEDURE sp_add_location  
        (in_location    VARCHAR(30),  
         in_address1    VARCHAR(30),  
         in_address2    VARCHAR(30),  
         zipcode        VARCHAR(10),  
         OUT out_status VARCHAR(30))  
    BEGIN  
        DECLARE CONTINUE HANDLER  
            FOR 1062  
            SET out_status='Duplicate Entry';  
      
        SET out_status='OK';  
        INSERT INTO locations  
            (location,address1,address2,zipcode)  
        VALUES  
            (in_location,in_address1,in_address2,zipcode);  
    END;  
複製代碼

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 當做一款APP,需要選擇本地圖片時,首先考慮的無疑是系統相冊,但是Android手機五花八門,再者手機像素的提升,大圖無法返回等異常因數,導致適配機型比較困難,微信、QQ都相繼的在自己的APP里集成了圖片選擇功能,放棄了系統提供的圖片選擇器,這裡仿造QQ做了一個本地圖片選擇器,PS:之前有人說"仿" ...
  • iOS10相冊相機閃退bughttp://www.jianshu.com/p/5085430b029fiOS 10 因蘋果健康導致閃退 crashhttp://www.jianshu.com/p/545bd1bf5a23麥克風、多媒體、地圖、通訊錄ios10相機等崩潰http://www.jians ...
  • swift字典 在swift中,key:key值一定是可hash的,一定是獨一無二的,swift的基本數據類型(String,Int,Float)都是可哈希的,所以都可以作為key值。 value:沒有要求 直接上代碼了,註釋給大家標的很明白 //創建字典並賦值 let dict = ["name" ...
  • 博客: Android 6.0 運行時許可權管理最佳實踐 github: https://github.com/yanzhenjie/AndPermission ...
  • EventBus是最近項目用到的,也只是會些簡單的功能,不過感覺功能蠻強大的。代碼鏈接:http://download.csdn.net/detail/qq_29774291/9629346 EventBus是Guava的事件處理機制,是設計模式中的觀察者模式(生產/消費者編程模型)的優雅實現。主要 ...
  • 1、基本概念 2、創建 3、插入 4、查詢 5、封裝 6、model 7、界面顯示 存數據 ...
  • Animation 效果 用法 1.非常簡單,導入兩個文件(UIView+SetRect) (UIView+ImageEffects) 源碼 github源碼:https://github.com/makingitbest/Animation 細節 1.下圖是效果圖的全部代碼 ...
  • Usage xml android:background= ?attr/zzbackground app:backgroundAttr= zzbackground //如果當前頁面要立即刷新,這裡傳入屬性名稱 比如R.attr.zzbackground 傳zzbackground即可 android ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...