当前位置: 首页 > 图文教程 > 数据库 > MYSQL > MySQL存储过程SAVEPOINT ROLLBACK to

MYSQL
Windows下对MySQL安装的故障诊断与排除
解析:校对确定 较为复杂的一些特殊情况
解析:轻松掌握 字符串文字字符集和校对
教你快速了解公共MySQL的数据库服务器层
MYSQL和ORACLE的一些操作区别
MySQL的6种日志详解
巧用MySQL InnoDB引擎锁机制解决死锁问题
怎样正确的解决 MySQL 中文模糊检索问题
教你轻松掌握如何保护MySQL中的重要数据
细化解析:怎样把你的MySQL完全中文化
带你轻松接触 MySQL中损坏的MyISAM表
解析:以mysql_开始的未定义引用错误
不同操作系统下的mysql数据库同步
MySQL优化之数据表的处理
安装MySQL错误归档处理
MySQL分页优化解析
数据库新手入门之MYSQL出错代码列表
经验之谈:MySQL与ASP.NET配合更强大
MySQL数据库的其它安全问题
RHEL下架设MYSQL集群

MYSQL 中的 MySQL存储过程SAVEPOINT ROLLBACK to


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-17   浏览: 143 ::
收藏到网摘: n/a

MySQL存储过程SAVEPOINT ROLLBACK to

示例如下:

以下为引用的内容:

DELIMITER $$

DROP PROCEDURE IF EXISTS `test`.`handlerdemo`$$

CREATE DEFINER=`root`@`localhost` PROCEDURE `handlerdemo`()

BEGIN

DECLARE X2 INT;

DECLARE CONTINUE HANDLER FOR SQLWARNING SET X2= 1;

DECLARE CONTINUE HANDLER FOR NOT FOUND SET X2 = 2;

DECLARE CONTINUE HANDLER FOR SQLSTATE '23000' SET X2= 3;

DECLARE CONTINUE HANDLER FOR SQLEXCEPTION SET X2 = 4;

START TRANSACTION;

SAVEPOINT savepoint_1;

BEGIN

INSERT INTO eugene VALUES (1);

INSERT INTO eugene VALUES (2);

SELECT X2;

end;

ROLLBACK TO SAVEPOINT savepoint_1;

iNSERT INTO eugene VALUES (3);

END$$


DELIMITER ;


#测试表

CREATE TABLE `eugene` (

t1` int(4) default NULL

)