MySQL 存储过程的异常处理
mysql>
mysql> delimiter $$
mysql>
mysql>
CREATE
PROCEDURE
myProc
-> (p_first_name
VARCHAR
(30),
-> p_last_name
VARCHAR
(30),
-> p_city
VARCHAR
(30),
-> p_description
VARCHAR
(30),
->
OUT
p_sqlcode
INT
,
->
OUT
p_status_message
VARCHAR
(100))
->
BEGIN
->
->
/* START Declare Conditions */
->
->
DECLARE
duplicate_key CONDITION
FOR
1062;
->
DECLARE
foreign_key_violated CONDITION
FOR
1216;
->
->
/* END Declare Conditions */
->
->
/* START Declare variables and cursors */
->
->
DECLARE
l_manager_id
INT
;
->
->
DECLARE
csr_mgr_id
CURSOR
FOR
->
SELECT
id
->
FROM
employee
->
WHERE
first_name=p_first_name
->
AND
last_name=p_last_name;
->
->
/* END Declare variables and cursors */
->
->
/* START Declare Exception Handlers */
->
->
DECLARE
CONTINUE
HANDLER
FOR
duplicate_key
->
BEGIN
->
SET
p_sqlcode=1052;
->
SET
p_status_message=
'Duplicate key error'
;
->
END
;
->
->
DECLARE
CONTINUE
HANDLER
FOR
foreign_key_violated
->
BEGIN
->
SET
p_sqlcode=1216;
->
SET
p_status_message=
'Foreign key violated'
;
->
END
;
->
->
DECLARE
CONTINUE
HANDLER
FOR
not
FOUND
->
BEGIN
->
SET
p_sqlcode=1329;
->
SET
p_status_message=
'No record found'
;
->
END
;
->
->
/* END Declare Exception Handlers */
->
->
/* START Execution */
->
->
SET
p_sqlcode=0;
->
OPEN
csr_mgr_id;
->
FETCH
csr_mgr_id
INTO
l_manager_id;
->
-> IF p_sqlcode<>0
THEN
/* Failed to get manager id*/
->
SET
p_status_message=CONCAT(p_status_message,
' when fetching manager id'
);
->
ELSE
->
INSERT
INTO
employee (first_name,id,city)
->
VALUES
(p_first_name,l_manager_id,p_city);
->
-> IF p_sqlcode<>0
THEN
/* Failed to insert new department */
->
SET
p_status_message=CONCAT(p_status_message,
->
' when inserting new department'
);
->
END
IF;
->
END
IF;
->
->
CLOSE
csr_mgr_id;
->
->
/* END Execution */
->
->
END
$$
Query OK, 0
rows
affected (0.02 sec)
mysql>
mysql> delimiter ;
mysql>
set
@myCode = 0;
Query OK, 0
rows
affected (0.00 sec)
mysql>
set
@myMessage = 0;
Query OK, 0
rows
affected (0.00 sec)
mysql>
mysql> call myProc(
'Jason'
,
'Martin'
,
'New City'
,
'New Description'
,@myCode,@myMessage);
Query OK, 1 row affected (0.00 sec)
mysql>
mysql>
select
@myCode, @myMessage;
+
---------+------------+
| @myCode | @myMessage |
+
---------+------------+
| 0 |
NULL
|
+
---------+------------+
1 row
in
set
(0.00 sec)
mysql>
mysql>
drop
procedure
myProc;
Query OK, 0
rows
affected (0.00 sec)
MySQL 存储过程的异常处理的更多相关文章
- mysql存储过程之异常处理篇
mysql存储过程也提供了对异常处理的功能:通过定义HANDLER来完成异常声明的实现 语法如下: DECLARE handler_type HANDLER FOR condition_value[, ...
- 详解MySQL存储过程的“异常处理”
阅读目录:存储过程的异常处理 定义异常处理 单一异常处理程序 continue exit 多个异常处理程序 关于错误编号和SQLSTATE码 使用3个处理程序 忽略某一异常的处理 异常处理的命名 异常 ...
- MySQL存储过程的异常处理
阅读目录:存储过程的异常处理 定义异常处理 单一异常处理程序 continue exit 多个异常处理程序 关于错误编号和SQLSTATE码 使用3个处理程序 忽略某一异常的处理 异常处理的命名 异常 ...
- MySQL存储过程学习笔记
MySQL在5.0以前并不支持存储过程,这使得MySQL在应用上大打折扣.MySQL 5.0终于开始支持存储过程了. MySQL的关键字大小写通用.该学习笔记对关键字使用大写:变量名,表名使用小写. ...
- MYSQL 存储过程 多表更新异常捕捉和异常处理方式
今天在做MYSQL 存储过程 多表更新的功能 多表更新时候注意事项 1.首先是确保多表更新能够一次执行,途中没有哪个表的sql语句错误 2.上线后修改表结构及字段,请注意检查是否影响mysql 过 ...
- MySQL存储过程(转)
一.MySQL 创建存储过程 "pr_add" 是个简单的 MySQL 存储过程,这个存储过程有两个 int 类型的输入参数 "a"."b" ...
- MySql存储过程
MySQL 存储过程 ```sql CREATE PROCEDURE myprocedure (IN para01 INTEGER) BEGIN DECLARE var01 CHAR(10); IF ...
- mysql存储过程之游标遍历数据表
原文:mysql存储过程之游标遍历数据表 今天写一个mysql存储过程,根据自己的需求要遍历一个数据表,因为对存储过程用的不多,语法不甚熟悉,加之存储过程没有调试环境,花了不少时间才慢慢弄好,故留个痕 ...
- MySQL 存储过程 经常使用语法
MySQL 存储过程是从 MySQL 5.0 開始添加的新功能.存储过程的长处有一箩筐.只是最基本的还是运行效率和SQL 代码封装.特别是 SQL 代码封装功能,假设没有存储过程,在外部程序訪问数据库 ...
随机推荐
- [POJ 3565] Ant
[题目链接] http://poj.org/problem?id=3565 [算法] KM算法求最小匹配 [代码] #include <algorithm> #include <bi ...
- stack 栈
其实今天我们主要讲的是搜索,但是留作业不知道怎么就突然全变成栈了. 其实栈和队列没什么区别,只是一个先进先出,一个先进后出.基本操作也是一样的. 栈(stack)又名堆栈,它是一种运算受限的线性表.其 ...
- K-means algorithm----PRML读书笔记
The K-means algorithm is based on the use of squared Euclidean distance as the measure of dissimila ...
- leetcode二分查找相关
目录 33/81搜索旋转排序数组 34在排序数组中查找元素的第一个和最后一个位置 35搜索插入位置 74搜索二维矩阵 300最长上升子序列,354俄罗斯套娃信封问题 33/81搜索旋转排序数组 假设按 ...
- Genesis 多边形闭轮廓填充算法
通过逐行扫描,计算得出直线与多边形相交点进行求解 原理图形如下所示: 相关函数: /// <summary> /// 求点P到线段L距离 /// </summary> /// ...
- linux shell 编程笔记
重定向和管道 输出重定向:把在终端输出的内容保存到文件上 输入重定向:通过文件的格式输入内容到终端 管道:把上一条命令的输出作为下一条命令的输入,如同管道一样,所有命令同时进行,同时处理数据,不 ...
- X - Vasya and Socks
Problem description Vasya has n pairs of socks. In the morning of each day Vasya has to put on a pai ...
- C#开发微信公众号——网页开发之微信网页授权
首先咱们先看下公众号的文档里面的介绍 上述图片的文字描述就是讲述了网页授权有什么用,就是为了获取微信用户的基本信息:授权回调域名的规范,说到域名回调的事情就不得不提一下设置网页授权域名 最好将这三个域 ...
- 24 javascript best practices for beginner(only 23 finally)
原文是英文,链接: http://net.tutsplus.com/tutorials/JavaScript-ajax/24-JavaScript-best-practices-for-beginne ...
- REST、RESTful、SOA
1.http://www.imooc.com/article/17650 2.SOA面向服务架构