MySQL异常处理浅析
作者:shichen2014 时间:2024-01-17 21:47:44
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 列表
http://dev.mysql.com/doc/refman/5.0/en/error-messages-server.html
更多错误列表见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,异常处理
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
vue 面包屑导航组件封装
2024-04-27 16:09:48
![](https://img.aspxhome.com/file/2023/2/132972_0s.jpg)
适合所有表的添加、删除、修改的函数
2008-04-15 15:29:00
vue地区选择组件教程详解
2023-07-02 16:49:48
Mysql 5.6添加修改用户名和密码的方法
2024-01-20 09:02:57
python re模块匹配贪婪和非贪婪模式详解
2023-04-19 01:44:16
JS版的date函数(和PHP的date函数一样)
2023-11-15 02:02:11
SQL Server 2008数据挖掘查询任务
2009-03-16 16:50:00
python实现去除空格及tab换行符的方法
2023-09-27 08:16:05
如何在Vue项目中应用TypeScript类
2023-07-02 16:51:36
![](https://img.aspxhome.com/file/2023/1/139801_0s.jpg)
手把手教你学会HBuilder打包APP
2022-03-25 00:43:53
![](https://img.aspxhome.com/file/2023/8/132458_0s.jpg)
MySQL优化之如何查找SQL效率低的原因
2024-01-12 21:03:55
python调用百度语音识别api
2023-02-13 10:23:48
![](https://img.aspxhome.com/file/2023/4/133414_0s.jpg)
python实现复制文件到指定目录
2022-09-25 20:53:12
使用 jQuery 实现表单验证功能
2023-07-02 05:31:04
![](https://img.aspxhome.com/file/2023/1/137081_0s.png)
Python3简单实现串口通信的方法
2022-03-10 03:39:53
浅谈Python type的使用
2021-05-17 05:58:59
在antd Form表单中select设置初始值操作
2024-05-02 17:03:12
常见的在Python中实现单例模式的三种方法
2022-11-08 01:42:09
vue使用代理解决请求跨域问题详解
2024-05-10 14:15:33
Python matplotlib通过plt.scatter画空心圆标记出特定的点方法
2023-06-26 14:19:03
![](https://img.aspxhome.com/file/2023/4/115874_0s.jpg)