MySQL数据库的异常处理
MySQL数据库操作过程中难免会出现会出现一些异常情况,遇到这种情况是,下文中介绍的内容将会帮助到大家。
对于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数据库的异常可能还有很多种,这里就先为大家介绍这几种,供大家参考,以后我还会继续为大家介绍这方面的知识。
【编辑推荐】
相关文章
- 如何通过 MySQL 的二进制日志恢复数据库数据
- 深入解析面向数据的哈希表性能
- 如何手动删除Oracle 11g数据库
- 101个MySQL调试和优化技巧
- 《架构真经:互联网技术架构的设计》分而治之
- 《Spark 官方文档》Spark SQL, DataFrames 以及 Datasets 编程指南(一)
- 《面向机器智能的TensorFlow实践》引言
- 《Spark 官方文档》Spark SQL, DataFrames 以及 Datasets 编程指南(二)
- 在 Linux 中修改 MySQL 或 MariaDB 的 Root 密码
- 为什么不能用memcached存储Session?
- 基础 RAID 介绍
- 如何在 Linux 中重置 MySQL 或者 MariaDB 的 root 密码
- 《用户至上:用户研究方法与实践》道德与法律问题
- 《Spark 官方文档》硬件配置
- 阿里CEO张勇:打破各企业边界 联手对抗黑灰产
- 阿里亮相网络安全周 展示亚洲市值最高企业的安全担当
- InnoDB 隔离模式对 MySQL 性能的影响
- 《大数据导论》理解大数据
- 我该如何向非技术人解释SQL注入?
- 沙龙报名啦:顶级架构师为您讲述企业互联网架构优化升级之路(阿里云授权中心沙龙计划)