文档章节

mysql 存储过程 获取错误信息 继续执行

 小田天
发布于 2016/07/14 17:24
字数 688
阅读 45
收藏 0

MySQL存储过程中的错误处理

作者:UncleToo  来源:翻译  日期:2014-05-20 7:53:13 
收藏  评论:( 2 )  阅读:1985

MySQL存储过程中的错误处理

       当MySQL执行存储过程遇到错误时,适当处理它,如继续执行或退出当前代码段,并返回有意义的错误提示是很重要的。一方面提高程序的容错能力,另一方便当程序出错时,开发人员也能准确定位错误的地方。

在本章MySQL教程中,我们将学习如何在存储过程中处理程序错误

 

声明处理程序

MySQL为我们提供了一种简单的方法定义处理程序,我们可以使用DECLARE HANDLER语句,如下所示:

1

DECLARE action HANDLER FOR condition_value statement;

如果其值与condition_value匹配,MySQL将执行statement,并且根据action值选择继续或退出当前代码块。

action 可以是以下两种:

  • CONTINUE:继续执行当前代码块

  • EXIT:退出当前代码块

condition_value 是一类特定的条件,可以使一下几种:

  • 一个MYSQL错误代码

  • 一个标准的SQLSTATE值,如SQLWARNING,NOTFOUND ,SQLEXCEPTION等

statement 是一个语句块,从BEGIN开始,到END结束。它可以是一个简单的sql语句,也可以是很复杂的逻辑语句。

 

MySQL错误处理的例子

例1:当程序发生错误,将has_error值置为1。如:

1

DECLARE CONTINUE HANDLER FOR SQLEXCEPTION SET has_error = 1;

 

例2:当遇到错误时,程序将回滚之前的操作,同时给出错误提示,然后退出当前程序块。如:

1

2

3

4

5

DECLARE EXIT HANDLER FOR SQLEXCEPTION

BEGIN

ROLLBACK;

Select '发生错误,执行将被回滚,程序将终止执行';

END;


例3:对于游标或select into操作,如果出现找不到记录的情况,将no_row_found赋值为1。如:

1

DECLARE CONTINUE HANDLER FOR NOT FOUND SET no_row_found = 1;

 

例4:如果出现重复键值,MySQL会给出1062的错误,将给出错误提示,程序继续运行。如:

1

2

DECLARE CONTINUE HANDLER FOR 1062

Select '错误:重复键值';

 

在存储过程中MySQL的处理程序的例子

首先我们创建一张数据表,为测试所用。

1

2

3

4

5

Create TABLE article_tags(

    article_id INT,

    tag_id     INT,

    PRIMARY KEY(article_id,tag_id)

);

article_tags表用来存储文章及标签之间的关系(多对多)。article_id存储文章ID,tag_id存储标签ID

 

其次,我们创建一个存储过程,实现插入文章ID和标签ID。

1

2

3

4

5

6

7

8

9

10

11

DELIMITER $$

Create PROCEDURE insert_article_tags(IN article_id INTIN tag_id INT)

BEGIN

    DECLARE CONTINUE HANDLER FOR 1062

    Select CONCAT('错误:重复键值 (',article_id,',',tag_id,')'AS msg;

    -- 插入新的记录

    Insert INTO article_tags(article_id,tag_id)

    VALUES(article_id,tag_id);

    -- 返回标签数量

    Select COUNT(*) FROM article_tags;

END

© 著作权归作者所有

共有 人打赏支持
粉丝 1
博文 79
码字总数 49841
作品 0
怀化
私信 提问
九、MySQL存储过程和函数

存储过程就是一条或者多条SQL语句的集合,可视为批文件,但是其作用不仅限于批处理。 9.1、创建存储过程和函数 存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别是...

运维菜鸟丶
2017/08/04
0
0
MySQL存储过程的“异常处理”

Q:何为异常? A:程序在执行过程中有可能出错,运行时错误叫做异常。 默认情况下,当存储过程运行出错时,过程会立即终止,并打印系统错误消息。 实验环境: mysql> use TENNISReading tab...

zsdnr
2017/07/21
0
0
【原创】MySQL 5.7 SYS系统SCHEMA

在说明系统数据库之前,先来看下MySQL在数据字典方面的演变历史: MySQL4.1 提供了information_schema 数据字典。从此可以很简单的用SQL语句来检索需要的系统元数据了。 MySQL5.5 提供了per...

david_yeung
2015/11/25
0
0
MySQL存储过程的“异常处理”

实验环境: mysql> use TENNIS Reading table information for completion of table and column names You can turn off this feature to get a quicker startup with -A Database changed m......

xmgdc
2017/07/03
0
0
【原创】mysql 错误缓冲堆栈

什么是错误缓冲堆栈呢? 举个很简单的例子,比如执行下面一条语句: mysql> INSERT INTO t_datetime VALUES(2,'4','5');ERROR 1292 (22007): Incorrect datetime value: '4' for column 'lo......

david_yeung
2015/12/25
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Linux 权限

权限 0 000 --- 无权限 1 001 --x 执行权限 2 010 -w- 写权限 3 011 -wx 写和执行 4 100 r-- 读权限 5 101 r-x 读和执行 6 110 rw- 读和写 7 111 rwx 读写执行 755 : rwxr-xr-x 660 : rw-r...

忙碌的小蜜蜂
5分钟前
0
0
21分钟教会你分析MaxCompute账单

21分钟教会你分析MaxCompute账单 背景 阿里云大计算服务MaxCompute是一款商业化的大数据分析平台,其计算资源有预付费和后付费两种计费方式。并且产品每天按照project为维度进行计量计费(账...

阿里云云栖社区
8分钟前
0
0
Docker使用 linuxserver/letsencrypt 生成SSL证书最全解析及实践

本文使用 HTTP 和 DNS 两种校验方式对 Docker 下 linuxserver/letsencrypt 项目进行了实践。生成SpringBoot可用证书,使用 Nginx 的 htpasswd 来对网站进行密码保护,并测试使用 fail2ban 防...

java菜分享
9分钟前
0
0
代码吃鸡:Python-Robocode

最近看到一个很有“未来感”的新闻: 一辆特斯拉在拉斯维加斯出了车祸,撞“死”了一个……emmmm……机器人。不知道是意外还是炒作,又或者是这位机器人故意碰瓷,反正人们也无法从受害者口中...

crossin
13分钟前
0
0
什么是公网IP、内网IP和NAT转换?

搞网络通信应用开发的程序员,可能会经常听到外网IP(即互联网IP地址)和内网IP(即局域网IP地址),但他们的区别是什么? 1、引言 搞网络通信应用开发的程序员,可能会经常听到外网IP(即互联网I...

Linux就该这么学
23分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部