欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mysql存儲過程中的異常處理解析

 更新時(shí)間:2016年09月15日 13:14:44   作者:cookiehu  
這篇文章主要為大家詳細(xì)介紹了mysql存儲過程中的異常處理,感興趣的小伙伴們可以參考一下

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

  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  

這里面需要注意幾點(diǎn): 

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

1、mysql_error_code,這個表示mysql的錯誤代碼,錯誤代碼是一個數(shù)字,完成是由mysql自己定義的,這個值可以參考mysql數(shù)據(jù)庫錯誤代碼及信息。

2、SQLSTATE [VALUE] sqlstate_value,這個同錯誤代碼類似形成一一對應(yīng)的關(guān)系,它是一個5個字符組成的字符串,關(guān)鍵的地方是它從ANSI SQL和ODBC這些標(biāo)準(zhǔn)中引用過來的,因此更加標(biāo)準(zhǔn)化,而不像上面的error_code完全是mysql自己定義給自己用的,這個和第一個類似也可以 參考mysql數(shù)據(jù)庫錯誤代碼及信息。

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其實(shí)表示的是成功執(zhí)行而不是錯誤,另外兩個就是上面的4和5的兩種情況。 

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

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

另一類是對對應(yīng)類型的錯誤的 處理,就是對某一群錯誤的處理,包括4、5、6這三種方式。這個是介紹了condition_value。另外還要注意的一個內(nèi)容是MySQL在默認(rèn)情況 下(也就是我們沒有定義處理錯誤的方法-handler)自己的錯誤處理機(jī)制:

1、對于SQLWARNING和NOT FOUND的處理方法就是無視錯誤繼續(xù)執(zhí)行,所以在游標(biāo)的例子里面如果我們沒有對repeat的條件判斷的那個值做個no_more_products=1的handler來處理,那么循環(huán)就會一直下去。

2、對于SQLEXCEPTION的話,其默認(rèn)的處理方法是在出現(xiàn)錯誤的地方就終止掉了。 

b、statement,這個比較簡單就是當(dāng)出現(xiàn)某種條件/錯誤時(shí),我們要執(zhí)行的語句,可以是簡單的如 SET  var = value這樣的簡單的語句,也可以是復(fù)雜的多行的語句,多行的話可以使用BEGIN  .....  END這里把語句包括在里面(這個好比delphi里面的情況,注意到我們的存儲過程也是多行的,所以也要BEGIN .... END)。

c、handler_action,這個表示當(dāng)執(zhí)行完上面的statement后,希望執(zhí)行怎樣的動作,這里包括CONTINUE、EXIT、UNDO, 表示繼續(xù)、退出、撤銷(暫時(shí)不支持)。這邊就是兩種動作,其實(shí)這兩種動作在上面也說過了,CONTINUE就是一個是SQLWARNING和NOT FOUND的默認(rèn)處理方法,而EXIT就是SQLEXCEPTION的默認(rèn)處理方法。 

另: 

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; 

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • mysql模糊查詢like與REGEXP的使用詳細(xì)介紹

    mysql模糊查詢like與REGEXP的使用詳細(xì)介紹

    每位程序員們應(yīng)該都知道,增刪改查是mysql最基本的功能,而其中查是最頻繁的操作,模糊查找是查詢中非常常見的操作,于是模糊查找成了必修課。下面這篇文章就給大家詳細(xì)介紹了mysql模糊查詢like與REGEXP的使用,有需要的朋友們可以參考學(xué)習(xí)。
    2016-12-12
  • Mysql處理Duplicate entry ‘6‘ for key ‘PRIMARY‘問題及解決

    Mysql處理Duplicate entry ‘6‘ for key 

    這篇文章主要介紹了Mysql處理Duplicate entry ‘6‘ for key ‘PRIMARY‘問題及解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • mysql4.0升級到mysql5(4.1),解決字符集問題

    mysql4.0升級到mysql5(4.1),解決字符集問題

    軟件升級部分就不說了,光說數(shù)據(jù)庫遷移。
    2009-09-09
  • 允許遠(yuǎn)程訪問MySQL的實(shí)現(xiàn)方式

    允許遠(yuǎn)程訪問MySQL的實(shí)現(xiàn)方式

    這篇文章主要介紹了允許遠(yuǎn)程訪問MySQL的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • 關(guān)于MySQL innodb_autoinc_lock_mode介紹

    關(guān)于MySQL innodb_autoinc_lock_mode介紹

    下面小編就為大家?guī)硪黄P(guān)于MySQL innodb_autoinc_lock_mode介紹。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-03-03
  • 安裝MySQL時(shí),輸入mysqld --install后,顯式該文件已存在問題

    安裝MySQL時(shí),輸入mysqld --install后,顯式該文件已存在問題

    這篇文章主要介紹了安裝MySQL時(shí),輸入mysqld --install后,顯式該文件已存在問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • mysql 添加索引 mysql 如何創(chuàng)建索引

    mysql 添加索引 mysql 如何創(chuàng)建索引

    本文將介紹mysql 如何創(chuàng)建索引,需要的朋友可以參考下
    2012-11-11
  • MySQL聯(lián)合索引與最左匹配原則的實(shí)現(xiàn)

    MySQL聯(lián)合索引與最左匹配原則的實(shí)現(xiàn)

    最左匹配原則在我們MySQL開發(fā)過程中和面試過程中經(jīng)常遇到,為了加深印象和理解,我在這里把MySQL的最左匹配原則詳細(xì)的講解一下,感興趣的可以了解一下
    2023-12-12
  • MySQL字符集亂碼及解決方案分享

    MySQL字符集亂碼及解決方案分享

    這篇文章主要給大家介紹了關(guān)于MySQL字符集亂碼及解決方案的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用MySQL具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • MySql逗號分割的字段數(shù)據(jù)分解為多行代碼示例

    MySql逗號分割的字段數(shù)據(jù)分解為多行代碼示例

    逗號分割的字符串可以作為分組數(shù)據(jù)的標(biāo)識符,用于對數(shù)據(jù)進(jìn)行分組和聚合操作,下面這篇文章主要給大家介紹了關(guān)于MySql逗號分割的字段數(shù)據(jù)分解為多行的相關(guān)資料,需要的朋友可以參考下
    2023-12-12

最新評論