MySQL数据库的异常处理

数据库 MySQL
MySQL数据库是很多人选择的数据库系统,那么对于MySQL数据库的异常处理,大家还是掌握了,这样就会便于大家日后对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数据库的异常可能还有很多种,这里就先为大家介绍这几种,供大家参考,以后我还会继续为大家介绍这方面的知识。

【编辑推荐】

  1. 如何关闭MySQL数据库中错误提示音
  2. 提高MySQL数据库查询效率的技巧(一)
  3. 认识MySQL数据库对服务器端光标的限制
  4. MySQL数据库只监听某个特定地址的方法
责任编辑:迎迎 来源: ddvip.com
相关推荐

2011-07-12 16:41:14

mysql处理异常

2011-05-26 14:43:49

ORACLE数据库异常处理

2011-08-05 14:02:17

MySQL数据库异常处理

2011-01-21 11:12:01

Spring

2010-05-31 15:23:02

MySQL数据库NUL

2010-09-29 08:52:34

MySQL

2021-01-26 13:40:44

mysql数据库

2011-08-10 16:01:11

OracleConstraint

2011-07-11 14:36:10

BinlogMysql

2017-10-23 16:06:41

数据库MySQL复制中断

2011-03-08 08:49:55

MySQL优化单机

2010-06-04 14:59:06

MySQL数据库

2010-05-24 18:16:52

MySQL数据库

2011-05-13 09:42:21

2011-08-15 15:14:54

SQL Server存储过程异常处理

2011-02-22 14:26:04

ProFTPD

2011-02-22 14:26:04

ProFTPD

2009-05-08 09:56:37

MaxDBMySQL数据库管理

2011-07-29 13:40:34

Oracle数据库PLSQL异常处理

2011-03-09 08:53:02

MySQL优化集群
点赞
收藏

51CTO技术栈公众号