谈谈MySQL的异常处理

本文涉及的产品
云数据库 RDS MySQL,集群版 2核4GB 100GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:
对于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 列表
[url]http://dev.mysql.com/doc/refman/5.0/en/error-messages-server.html[/url]
更多错误列表见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 @= 1;
    -> INSERT INTO t VALUES (1);
    -> SET @= 2;
    -> INSERT INTO t VALUES (1);
    -> SET @= 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;
+
------+

| @|
+
------+

| 2 | 
+
------+

row in set (0.00 sec)

mysql> call handlerdemo();
Query OK, 0 rows affected (0.00 sec)

mysql> select @x;
+
------+

| @|
+
------+

| 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 @= 1;
    -> INSERT INTO t VALUES (1);
    -> SET @= 2;
    -> INSERT INTO t VALUES (1);
    -> SET @= 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;
+
------+

| @|
+
------+

| 3 | 
+
------+

row in set (0.00 sec)

mysql> call handlerdemo();
Query OK, 0 rows affected (0.00 sec)

mysql> select @x;
+
------+

| @|
+
------+

| 3 | 
+
------+

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 @= 1;
    -> INSERT INTO t(s1) VALUES (1);
    -> SET @= 2;
    -> INSERT INTO t(s1) VALUES (1);
    -> SET @= 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 | 
+
----+----+

row in set (0.00 sec)
遇到错误的时候插入的新记录。

mysql> select @x;
+
------+

| @|
+
------+

| 3 | 
+
------+

row in set (0.00 sec)
4、如果有新的体会,我会再发出来共享。





本文转自 yarin 51CTO博客,原文链接: http://blog.51cto.com/yueliangdao0608/81263 ,如需转载请自行联系原作者
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
21天前
|
关系型数据库 MySQL Linux
Linux centos 6.5 - Mysql 安装 、卸载、修改密码、忘记密码 并异常处理
Linux centos 6.5 - Mysql 安装 、卸载、修改密码、忘记密码 并异常处理
26 0
|
2月前
|
Ubuntu 关系型数据库 MySQL
Mysql Access denied for user ‘root‘@ ‘*.*.*.*‘ (using password: YES)异常处理
Mysql Access denied for user ‘root‘@ ‘*.*.*.*‘ (using password: YES)异常处理
70 0
Mysql Access denied for user ‘root‘@ ‘*.*.*.*‘ (using password: YES)异常处理
|
SQL MySQL 关系型数据库
sqoop将mysql数据导入hbase、hive的常见异常处理
sqoop将mysql数据导入hbase、hive的常见异常处理一、需求:1、将以下这张表(test_goods[id,goods_name,goods_price])数据导入Hbase 由此,编写如下sqoop导入命令 sqoop import -D sqoop.
2808 0
|
关系型数据库 MySQL 数据库
Mysql主从同步异常处理
一、在Mysql中,如果是主从(包括一主多从)模式的数据库配置。请在创建数据库和对数控库进行增删改查操作,一定要在主库进行,从库主要提供主库备份和数据查询功能,请勿直接在从库进行增删改查。
1126 0
|
SQL 关系型数据库 MySQL
|
存储 关系型数据库 MySQL
|
Java 关系型数据库 MySQL
最新版本mysql jdbc驱动包获取表定义信息空指针异常处理方法
在使用最新的mysql-connector-java 6.0.5时,获取表定义信息会抛出空指针异常: [2016-12-15 10:19:28][DEBUG][com.frameworkset.
1337 0
|
SQL 监控 关系型数据库
MySQL主备复制原理、实现及异常处理
复制概述 MySQL支持三种复制方式:基于行(Row)的复制、基于语句(Statement)的复制和混合类型(Mixed)的复制。 基于语句的复制早在3.23版本中就存在,而基于行的复制方式在5.1版本中才被加进来。
1459 0