`
winphfar
  • 浏览: 47759 次
  • 性别: Icon_minigender_1
  • 来自: 上海
文章分类
社区版块
存档分类
最新评论

MySQL5的异常处理

阅读更多

1. Sample Problem: Log Of Failures 问题样例:故障记录

当INSERT失败时,我希望能将其记录在日志文件中我们用来展示出错处理的问题样例是很普通的。我希望得到错误的记录。当INSERT失败时,我想在另一个文件中记下这些错误的信息,例如出错时间,出错原因等。我对插入特别感兴趣的原因是它将违反外键关联的约束

2. Sample Problem: Log Of Failures (2)

mysql> CREATE TABLE t2

1 INT, PRIMARY KEY (s1))

engine=innodb;//

mysql> CREATE TABLE t3 (s1 INT, KEY (s1),

FOREIGN KEY (s1) REFERENCES t2 (s1))

engine=innodb;//

mysql> INSERT INTO t3 VALUES (5);//

...

ERROR 1216 (23000): Cannot add or update a child row: a foreign key

constraint fails(这里显示的是系统的出错信息)

我开始要创建一个主键表,以及一个外键表。我们使用的是InnoDB,因此外键关联检查是打开的。然后当我向外键表中插入非主键表中的值时,动作将会失败。当然这种条件下可以很快找到错误号1216。

3. Sample Problem: Log Of Failures

CREATE TABLE error_log (error_message

CHAR(80))//

下一步就是建立一个在做插入动作出错时存储错误的表。

4. Sample Problem: Log Of Errors

CREATE PROCEDURE p22 (parameter1 INT)

BEGIN

DECLARE EXIT HANDLER FOR 1216

INSERT INTO error_log VALUES

(CONCAT('Time: ',current_date,

'. Foreign Key Reference Failure For

Value = ',parameter1));

INSERT INTO t3 VALUES (parameter1);

END;//

上面就是我们的程序。这里的第一个语句DECLARE EXIT HANDLER是用来处理异常的。意思是如果错误1215发生了,这个程序将会在错误记录表中插入一行。EXIT意思是当动作成功提交后退出这个复合语句。

5. Sample Problem: Log Of Errors

CALL p22 (5) //

调用这个存储过程会失败,这很正常,因为5值并没有在主键表中出现。但是没有错误信息返回因为出错处理已经包含在过程中了。t3表中没有增加任何东西,但是error_log表中记录下了一些信息,这就告诉我们INSERT into table t3动作失败。

DECLARE HANDLER syntax 声明异常处理的语法

DECLARE

{ EXIT | CONTINUE }

HANDLER FOR

{ error-number | { SQLSTATE error-string } | condition }

SQL statement

上面就是错误处理的用法,也就是一段当程序出错后自动触发的代码。MySQL允许两种处理器,一种是EXIT处理,我们刚才所用的就是这种。另一种就是我们将要演示的,CONTINUE处理,它跟EXIT处理类似,不同在于它执行后,原主程序仍然继续运行,那么这个复合语句就没有出口了。

1. DECLARE CONTINUE HANDLER example CONTINUE处理例子

CREATE TABLE t4 (s1 int,primary key(s1));//

CREATE PROCEDURE p23 ()

BEGIN

DECLARE CONTINUE HANDLER

FOR SQLSTATE '23000' SET @x2 = 1;

SET @x = 1;

INSERT INTO t4 VALUES (1);

SET @x = 2;

INSERT INTO t4 VALUES (1);

SET @x = 3;

END;//

这是MySQL参考手册上的CONTINUE处理的例子,这个例子十分好,所以我把它拷贝到这里。通过这个例子我们可以看出CONTINUE处理是如何工作的。

2. DECLARE CONTINUE HANDLER声明CONTINUE异常处理

CREATE TABLE t4 (s1 int,primary key(s1));//

CREATE PROCEDURE p23 ()

BEGIN

DECLARE CONTINUE HANDLER

FOR SQLSTATE '23000' SET @x2 = 1; <--

SET @x = 1;

INSERT INTO t4 VALUES (1);

SET @x = 2;

INSERT INTO t4 VALUES (1);

SET @x = 3;

END;//

这次我将为SQLSTATE值定义一个处理程序。还记得前面我们使用的MySQL错误代码1216吗?事实上这里的23000SQLSTATE是更常用的,当外键约束出错或主键约束出错就被调用了。

3. DECLARE CONTINUE HANDLER

CREATE TABLE t4 (s1 int,primary key(s1));//

CREATE PROCEDURE p23 ()

BEGIN

DECLARE CONTINUE HANDLER

FOR SQLSTATE '23000' SET @x2 = 1;

SET @x = 1; <--

INSERT INTO t4 VALUES (1);

SET @x = 2;

INSERT INTO t4 VALUES (1);

SET @x = 3;

END;//

这个存储过程的第一个执行的语句是"SET @x = 1"。

4. DECLARE CONTINUE HANDLER example

CREATE TABLE t4 (s1 int,primary key(s1));//

CREATE PROCEDURE p23 ()

BEGIN

DECLARE CONTINUE HANDLER

FOR SQLSTATE '23000' SET @x2 = 1;

SET @x = 1;

INSERT INTO t4 VALUES (1);

SET @x = 2;

INSERT INTO t4 VALUES (1); <--

SET @x = 3;

END;//

运行后值1被插入到主键表中。

5. DECLARE CONTINUE HANDLER

CREATE TABLE t4 (s1 int,primary key(s1));//

CREATE PROCEDURE p23 ()

BEGIN

DECLARE CONTINUE HANDLER

FOR SQLSTATE '23000' SET @x2 = 1;

SET @x = 1;

INSERT INTO t4 VALUES (1);

SET @x = 2; <--

INSERT INTO t4 VALUES (1);

SET @x = 3;

END;//

然后@x的值变为2。

0
0
分享到:
评论

相关推荐

    MySQL定义异常和异常处理详解

    MySQL中的异常处理是数据库编程中不可或缺的一部分,它允许开发者预设对可能出现的错误或异常的响应,从而确保程序的稳定性和健壮性。在MySQL中,异常定义和处理主要是通过`DECLARE`语句来实现的。 1. **异常定义**...

    MySQL存储过程的异常处理方法

    本实例展示了如何在MySQL存储过程中实现异常处理,以捕获并处理可能出现的错误。 首先,我们注意到在创建存储过程`myProc`时,使用了`delimiter $$`来改变MySQL客户端的语句分隔符,这是为了在存储过程中使用多个...

    [MySQL] 存储过程错误异常处理例子

    本篇文章将详细探讨如何在MySQL的存储过程中使用`DECLARE EXIT HANDLER FOR SQLEXCEPTION`来实现错误异常处理。 首先,我们需要了解存储过程的基本结构。一个存储过程通常由`CREATE PROCEDURE`语句定义,包括参数...

    mysql8和mysql5的连接驱动jar包

    同时,对于生产环境,还需要配置合适的错误处理和异常捕获机制,以及数据库连接的关闭操作,以避免资源泄露。 总的来说,MySQL8的JDBC驱动不仅提供了与MySQL5相比的诸多新特性和性能提升,还增强了安全性。开发者在...

    MySQL存储过程中一些基本的异常处理教程

    Mysql 支持异常处理,通过定义 CONTINUE/EXIT 异常处理的 HANDLER 来捕获 SQLWARNING/NOT FOUND/SQLEXCEPTION (警告 / 无数据 / 其他异常)。其中, FOR 后面可以改为 SQLWARNING, NOT FOUND, SQLEXCEPTION 来指示...

    mysql常见异常 mysql常见异常

    MySQL是世界上最流行的关系型数据库管理系统之一,然而在日常使用中,由于各种原因,我们可能会遇到各种异常和错误。这些异常通常以错误代码的形式出现,帮助我们识别问题所在并找到解决方案。以下是一些常见的MySQL...

    处理MySQL访问异常故障.pdf

    ### 处理MySQL访问异常故障 #### 背景与问题描述 在处理一个使用Java开发的数据分析系统中,后台采用MySQL数据库作为数据存储层。最近遇到了无法查询和写入数据的问题。该MySQL服务器运行在CentOS 6.X环境下,硬件...

    PHP 5 + MYSQL 5 Web应用开发宝典

    1. **PHP基础**:介绍PHP语法基础,包括变量、常量、数据类型、控制结构(如if/else,switch)、函数和类的使用,以及错误和异常处理。 2. **MySQL数据库管理**:讲解如何创建、操作和管理MySQL数据库,包括创建表...

    MySQL异常处理浅析

    MySQL 异常处理浅析 MySQL 异常处理是数据库管理员和开发者需要掌握的一项重要技能。下面将对 MySQL 异常处理进行浅析,涵盖 DECLARE 语句、condition_value 的使用、SQLSTATE 的介绍、ERROR CODE 列表以及实际操作...

    MySql 5数据库驱动包

    此外,驱动包还提供了处理异常、执行批量SQL、自动重连等功能,帮助开发者更方便地处理数据库操作。 总之,MySQL 5数据库驱动包是Java程序员连接MySQL数据库的必备工具,它的正确使用能有效提升开发效率,确保应用...

    PHP6与MySQL5基础教程第三版源代码(09.11.25更新)

    此外,PHP6对错误处理也做了改进,引入了异常处理机制,使得错误处理更加统一和规范。 MySQL5,是广泛使用的开源关系型数据库管理系统,其主要特性包括事务处理、存储过程、触发器、视图等。这些特性使得MySQL5在...

    mySQL事务处理

    关于mysql的事务处理 public static void StartTransaction(Connection con, String[] sqls) throws Exception { if (sqls == null) { return; } Statement sm = null; try { // 事务开始 System....

    杜江 php5与MySQL5 web开发技术详解 光盘代码

    7. 错误处理与调试:PHP5提供了丰富的错误报告机制,书中的实例代码可能包含如何处理运行时错误和异常,以及如何使用调试工具进行问题排查。 8. AJAX与JavaScript:可能讲解了如何使用PHP与JavaScript结合,实现...

    PyQt5 + MySQL简单示例

    这个简单的示例展示了如何将PyQt5的GUI功能与MySQL数据库的后端数据处理能力结合起来。通过这种方式,你可以创建出功能强大且用户友好的数据管理应用程序,满足各种业务需求。在实际项目中,你可能还需要考虑线程...

    MySQL5新特性之存储过程MySQL5新特性之存储过程

    4. **异常处理**:通过`DECLARE`、`BEGIN...END`和`HANDLER`语句,MySQL5提供了错误处理机制,可以在存储过程中捕获并处理异常,增强了程序的健壮性。 5. **动态SQL**:MySQL5支持在存储过程中执行动态生成的SQL...

    php5+mysql5简体中文教程.rar

    3. PHP5错误和异常处理:学习如何捕获和处理运行时错误,以及使用异常来更有效地控制程序流程。 4. 文件和目录操作:教授如何在PHP中读写文件、创建和删除目录,以及处理上传和下载等文件操作。 5. PHP5与HTML的...

    PHP5 MYSQL5 (中文) 手册打包下载

    3. **异常处理**:引入异常处理机制,使得错误处理更加规范和有序,便于调试和维护。 4. **预定义类库**:如DOM、PDO(PHP Data Objects)、SimpleXML等,提供了对XML文档操作和数据库访问的标准化接口。 5. **...

    php5与mysql5 web开发详解 源码

    2. **错误处理**:增加了异常处理机制,使得程序的错误处理更加规范和严谨。 3. **类型提示**:函数参数可以声明预期的数据类型,提高了代码的健壮性。 4. **魔术常量和魔术方法**:提供了一些特殊情况下自动调用的...

    PHP5与MySQL5从入门到精通

    PHP5相较于早期版本,在面向对象编程上有重大改进,增加了许多新特性,如更好的类支持、异常处理等。这部分内容旨在帮助读者建立扎实的PHP编程基础。 接着,书籍会进一步讲解MySQL5的基础,包括数据库设计、SQL语言...

Global site tag (gtag.js) - Google Analytics