| 導購 | 订阅 | 在线投稿
分享
 
 
當前位置: 王朝網路 >> mysql >> 帶你輕松接觸MySQL數據庫的異常處理
 

帶你輕松接觸MySQL數據庫的異常處理

2008-06-01 03:23:18  編輯來源:互聯網  简体版  手機版  評論  字體: ||
 
 
  對于MySQL的異常處理,本人不常用。不過我覺得還是有寫下來的必要。

  標准格式

  DECLARE handler_type HANDLER FOR condition_value[,...] statement

  handler_type:

  CONTINUE

  | EXIT

  | UNDO --暫時不支持

  condition_value:

  SQLSTATE [VALUE] sqlstate_value

  | condition_name

  | SQLWARNING

  | NOT FOUND

  | SQLEXCEPTION

  | mysql_error_code

  condition_value細節

  1、MySQL ERROR CODE 列表

  如果需要查看更多的錯誤列表可以直接到MySQL安裝路徑下。

  比如我的/usr/local/mysql/share/mysql/errmsg.txt

  說明:SQLSTATE [VALUE] sqlstate_value這種格式是專門爲ANSI SQL 和 ODBC以及其他的標准.

  並不是所有的MySQL ERROR CODE 都映射到SQLSTATE。

  2、假如不需要插入ERROR CODE,可以用速記條件來代替

  SQLWARNING 代表所有以01開頭的錯誤代碼

  NOT FOUND 代表所有以02開頭的錯誤代碼,當然也可以代表一個遊標到達數據集的末尾。

  SQLEXCEPTION 代表除了SQLWARNING和NOT FOUND 的所有錯誤代碼。

  3、具體示例:

  CREATE TABLE t (s1 int,primary key (s1));

  mysql> use t_girl

  Database changed

  mysql> CREATE TABLE t (s1 int,primary key (s1));

  Query OK, 0 rows affected (0.00 sec)

  mysql>

  mysql>

  mysql> DELIMITER ||

  mysql> CREATE PROCEDURE handlerdemo ()

  -> BEGIN

  -> DECLARE EXIT HANDLER FOR SQLSTATE '23000' BEGIN END; -- 遇到重複鍵值就退出

  -> SET @x = 1;

  -> INSERT INTO t VALUES (1);

  -> SET @x = 2;

  -> INSERT INTO t VALUES (1);

  -> SET @x = 3;

  -> END||

  Query OK, 0 rows affected (0.00 sec)

  mysql> DELIMITER ;

  mysql> call handlerdemo();

  Query OK, 0 rows affected (0.00 sec)

  mysql> select @x;

  +------+

  | @x |

  +------+

  | 2 |

  +------+

  1 row in set (0.00 sec)

  mysql> call handlerdemo();

  Query OK, 0 rows affected (0.00 sec)

  mysql> select @x;

  +------+

  | @x |

  +------+

  | 1 |

  +------+

  1 row in set (0.00 sec)

  mysql>

  遇到錯誤繼續的情況

  mysql> truncate table t;

  Query OK, 0 rows affected (0.01 sec)

  mysql> DELIMITER $$

  mysql> DROP PROCEDURE IF EXISTS `t_girl`.`handlerdemo`$$

  Query OK, 0 rows affected (0.00 sec)

  mysql> CREATE DEFINER=`root`@`localhost` PROCEDURE `handlerdemo`()

  -> BEGIN

  -> DECLARE CONTINUE HANDLER FOR SQLSTATE '23000' BEGIN END;

  -> SET @x = 1;

  -> INSERT INTO t VALUES (1);

  -> SET @x = 2;

  -> INSERT INTO t VALUES (1);

  -> SET @x = 3;

  -> END$$

  Query OK, 0 rows affected (0.01 sec)

  mysql> DELIMITER ;

  mysql> call handlerdemo();

  Query OK, 0 rows affected (0.00 sec)

  mysql> select @x;

  +------+

  | @x |

  +------+

  | 3 |

  +------+

  1 row in set (0.00 sec)

  mysql> call handlerdemo();

  Query OK, 0 rows affected (0.00 sec)

  mysql> select @x;

  +------+

  | @x |

  +------+

  | 3 |

  +------+

  1 row in set (0.00 sec)

  mysql>

  我們可以看到,始終執行到最後。

  當然,上面的SQLSTATE '23000'可以替換爲1062。

  警告:

  mysql> alter table t add s2 int not null;

  Query OK, 0 rows affected (0.01 sec)

  Records: 0 Duplicates: 0 Warnings: 0

  這個列沒有默認值,插入的時候會出現警告或者1364錯誤提示。

  mysql> DELIMITER $$

  mysql> DROP PROCEDURE IF EXISTS `t_girl`.`handlerdemo`$$

  Query OK, 0 rows affected, 1 warning (0.00 sec)

  mysql> CREATE DEFINER=`root`@`localhost` PROCEDURE `handlerdemo`()

  -> BEGIN

  -> DECLARE CONTINUE HANDLER FOR 1062 BEGIN END;

  -> DECLARE CONTINUE HANDLER FOR SQLWARNING

  -> BEGIN

  -> update t set s2 = 2;

  -> END;

  -> DECLARE CONTINUE HANDLER FOR 1364

  -> BEGIN

  -> INSERT INTO t(s1,s2) VALUES (1,3);

  -> END;

  -> SET @x = 1;

  -> INSERT INTO t(s1) VALUES (1);

  -> SET @x = 2;

  -> INSERT INTO t(s1) VALUES (1);

  -> SET @x = 3;

  -> END$$

  Query OK, 0 rows affected (0.00 sec)

  mysql> DELIMITER ;

  mysql> call handlerdemo();

  Query OK, 0 rows affected (0.00 sec)

  mysql> select * from t;

  +----+----+

  | s1 | s2 |

  +----+----+

  | 1 | 3 |

  +----+----+

  1 row in set (0.00 sec)

  遇到錯誤時,插入的新記錄。

  mysql> select @x;

  +------+

  | @x |

  +------+

  | 3 |

  +------+

  1 row in set (0.00 sec)
 
 
 
上一篇《使用實例管理器輕松管理多個MySQL實例》
下一篇《循序漸進講解MySQL數據庫的性能調整》
 
 
 
日版寵物情人插曲《Winding Road》歌詞

日版寵物情人2017的插曲,很帶節奏感,日語的,女生唱的。 最後聽見是在第8集的時候女主手割傷了,然後男主用嘴幫她吸了一下,插曲就出來了。 歌手:Def...

兄弟共妻,我成了他們夜裏的美食

老鍾家的兩個兒子很特別,就是跟其他的人不太一樣,魔一般的執著。兄弟倆都到了要結婚的年齡了,不管自家老爹怎麽磨破嘴皮子,兄弟倆說不娶就不娶,老父母爲兄弟兩操碎了心...

如何磨出破洞牛仔褲?牛仔褲怎麽剪破洞?

把牛仔褲磨出有線的破洞 1、具體工具就是磨腳石,下面墊一個硬物,然後用磨腳石一直磨一直磨,到把那塊磨薄了,用手撕開就好了。出來的洞啊很自然的。需要貓須的話調幾...

我就是掃描下圖得到了敬業福和愛國福

先來看下敬業福和愛國福 今年春節,支付寶再次推出了“五福紅包”活動,表示要“把欠大家的敬業福都還給大家”。 今天該活動正式啓動,和去年一樣,需要收集“五福”...

冰箱異味産生的原因和臭味去除的方法

有時候我們打開冰箱就會聞到一股異味,冰箱裏的這種異味是因爲一些物質發出的氣味的混合體,聞起來讓人惡心。 産生這些異味的主要原因有以下幾點。 1、很多人有這種習...

《極品家丁》1-31集大結局分集劇情介紹

簡介 《極品家丁》講述了現代白領林晚榮無意回到古代金陵,並追隨蕭二小姐化名“林三”進入蕭府,不料卻陰差陽錯上演了一出低級家丁拼搏上位的“林三升職記”。...

李溪芮《極品家丁》片尾曲《你就是我最愛的寶寶》歌詞

你就是我最愛的寶寶 - 李溪芮 (電視劇《極品家丁》片尾曲) 作詞:常馨內 作曲:常馨內 你的眉 又鬼馬的挑 你的嘴 又壞壞的笑 上一秒吵鬧 下...

烏梅的功效與作用以及烏梅的食用禁忌有哪些?

烏梅,又稱春梅,中醫認爲,烏梅味酸,性溫,無毒,具有安心、除熱、下氣、祛痰、止渴調中、殺蟲的功效,治肢體痛、肺痨病。烏梅泡水喝能治傷寒煩熱、止吐瀉,與幹姜一起制...

什麽是脂肪粒?如何消除臉部脂肪粒?

什麽是脂肪粒 在我們的臉上總會長一個個像脂肪的小顆粒,弄也弄不掉,而且顔色還是白白的。它既不是粉刺也不是其他的任何痘痘,它就是脂肪粒。 脂肪粒雖然也是由油脂...

網絡安全治理:國家安全保障的主要方向是打擊犯罪,而不是處置和懲罰受害者

來源:中國青年報 新的攻擊方法不斷湧現,黑客幾乎永遠占據網絡攻擊的上風,我們不可能通過技術手段杜絕網絡攻擊。國家安全保障的主要方向是打擊犯罪,而不是處置和懲罰...

 
 
 
對于MySQL的異常處理,本人不常用。不過我覺得還是有寫下來的必要。 標准格式 DECLARE handler_type HANDLER FOR condition_value[,...] statement handler_type: CONTINUE | EXIT | UNDO --暫時不支持 condition_value: SQLSTATE [VALUE] sqlstate_value | condition_name | SQLWARNING | NOT FOUND | SQLEXCEPTION | mysql_error_code condition_value細節 1、MySQL ERROR CODE 列表 如果需要查看更多的錯誤列表可以直接到MySQL安裝路徑下。 比如我的/usr/local/mysql/share/mysql/errmsg.txt 說明:SQLSTATE [VALUE] sqlstate_value這種格式是專門爲ANSI SQL 和 ODBC以及其他的標准. 並不是所有的MySQL ERROR CODE 都映射到SQLSTATE。 2、假如不需要插入ERROR CODE,可以用速記條件來代替 SQLWARNING 代表所有以01開頭的錯誤代碼 NOT FOUND 代表所有以02開頭的錯誤代碼,當然也可以代表一個遊標到達數據集的末尾。 SQLEXCEPTION 代表除了SQLWARNING和NOT FOUND 的所有錯誤代碼。 3、具體示例: CREATE TABLE t (s1 int,primary key (s1)); mysql> use t_girl Database changed mysql> CREATE TABLE t (s1 int,primary key (s1)); Query OK, 0 rows affected (0.00 sec) mysql> mysql> mysql> DELIMITER || mysql> CREATE PROCEDURE handlerdemo () -> BEGIN -> DECLARE EXIT HANDLER FOR SQLSTATE '23000' BEGIN END; -- 遇到重複鍵值就退出 -> SET @x = 1; -> INSERT INTO t VALUES (1); -> SET @x = 2; -> INSERT INTO t VALUES (1); -> SET @x = 3; -> END|| Query OK, 0 rows affected (0.00 sec) mysql> DELIMITER ; mysql> call handlerdemo(); Query OK, 0 rows affected (0.00 sec) mysql> select @x; +------+ | @x | +------+ | 2 | +------+ 1 row in set (0.00 sec) mysql> call handlerdemo(); Query OK, 0 rows affected (0.00 sec) mysql> select @x; +------+ | @x | +------+ | 1 | +------+ 1 row in set (0.00 sec) mysql> 遇到錯誤繼續的情況 mysql> truncate table t; Query OK, 0 rows affected (0.01 sec) mysql> DELIMITER $$ mysql> DROP PROCEDURE IF EXISTS `t_girl`.`handlerdemo`$$ Query OK, 0 rows affected (0.00 sec) mysql> CREATE DEFINER=`root`@`localhost` PROCEDURE `handlerdemo`() -> BEGIN -> DECLARE CONTINUE HANDLER FOR SQLSTATE '23000' BEGIN END; -> SET @x = 1; -> INSERT INTO t VALUES (1); -> SET @x = 2; -> INSERT INTO t VALUES (1); -> SET @x = 3; -> END$$ Query OK, 0 rows affected (0.01 sec) mysql> DELIMITER ; mysql> call handlerdemo(); Query OK, 0 rows affected (0.00 sec) mysql> select @x; +------+ | @x | +------+ | 3 | +------+ 1 row in set (0.00 sec) mysql> call handlerdemo(); Query OK, 0 rows affected (0.00 sec) mysql> select @x; +------+ | @x | +------+ | 3 | +------+ 1 row in set (0.00 sec) mysql> 我們可以看到,始終執行到最後。 當然,上面的SQLSTATE '23000'可以替換爲1062。 警告: mysql> alter table t add s2 int not null; Query OK, 0 rows affected (0.01 sec) Records: 0 Duplicates: 0 Warnings: 0 這個列沒有默認值,插入的時候會出現警告或者1364錯誤提示。 mysql> DELIMITER $$ mysql> DROP PROCEDURE IF EXISTS `t_girl`.`handlerdemo`$$ Query OK, 0 rows affected, 1 warning (0.00 sec) mysql> CREATE DEFINER=`root`@`localhost` PROCEDURE `handlerdemo`() -> BEGIN -> DECLARE CONTINUE HANDLER FOR 1062 BEGIN END; -> DECLARE CONTINUE HANDLER FOR SQLWARNING -> BEGIN -> update t set s2 = 2; -> END; -> DECLARE CONTINUE HANDLER FOR 1364 -> BEGIN -> INSERT INTO t(s1,s2) VALUES (1,3); -> END; -> SET @x = 1; -> INSERT INTO t(s1) VALUES (1); -> SET @x = 2; -> INSERT INTO t(s1) VALUES (1); -> SET @x = 3; -> END$$ Query OK, 0 rows affected (0.00 sec) mysql> DELIMITER ; mysql> call handlerdemo(); Query OK, 0 rows affected (0.00 sec) mysql> select * from t; +----+----+ | s1 | s2 | +----+----+ | 1 | 3 | +----+----+ 1 row in set (0.00 sec) 遇到錯誤時,插入的新記錄。 mysql> select @x; +------+ | @x | +------+ | 3 | +------+ 1 row in set (0.00 sec)
󰈣󰈤
 
 
 
  免責聲明:本文僅代表作者個人觀點,與王朝網路無關。王朝網路登載此文出於傳遞更多信息之目的,並不意味著贊同其觀點或證實其描述,其原創性以及文中陳述文字和內容未經本站證實,對本文以及其中全部或者部分內容、文字的真實性、完整性、及時性本站不作任何保證或承諾,請讀者僅作參考,並請自行核實相關內容。
 
 
夏末午後的美麗女生
天生麗質_唯美動人
清新素雅的靓麗女生
完美絕倫_秀色可餐
芙蓉古鎮(一)
就是不一樣的街燈&#;
百態
荷一組(三張)
 
>>返回首頁<<
 
 熱帖排行
 
 
 
 
© 2005- 王朝網路 版權所有