PHP 事务回滚实例

#若已存在该表,就将其删除;否则创建新的表。
DROP table IF EXISTS users;
CREATE TABLE users(
`user_name` varchar(5) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

#若已存在该存储过程,就将其删除;否则创建新的存储过程
DROP PROCEDURE IF EXISTS inserOrUpdate;
CREATE PROCEDURE inserOrUpdate()
BEGIN
#--------------------
#SQLEXCEPTION 对应存储过程执行中所有异常
#@Auth:CHK
#@time:2014-9-12 11:37:42
#--------------------
#如sql异常,事务回滚
DECLARE CONTINUE HANDLER FOR SQLEXCEPTION BEGIN ROLLBACK;END;

#开启事务
START TRANSACTION;
insert into users (user_name) values (‘1‘);
insert into users (user_name) values (‘2‘);
SELECT errno;
select * from users;
COMMIT;
END;

call inserOrUpdate();

---------------------------------------------------------------------------

#若已存在该表,就将其删除;否则创建新的表。
DROP table IF EXISTS users;
CREATE TABLE users(
`user_name` varchar(5) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

#若已存在该存储过程,就将其删除;否则创建新的存储过程
DROP PROCEDURE IF EXISTS inserOrUpdate;
CREATE PROCEDURE inserOrUpdate()
BEGIN
#--------------------
#SQLEXCEPTION 对应存储过程执行中所有异常
#@Auth:CHK
#@time:2014-9-12 11:37:42
#--------------------
#标志是否出错
DECLARE errno TINYINT DEFAULT ‘0‘;
#如sql异常,将errno设置为1且后续执行退出
#DECLARE CONTINUE HANDLER FOR SQLEXCEPTION BEGIN ROLLBACK;SET errno = 1; END;

DECLARE CONTINUE HANDLER FOR SQLEXCEPTION
BEGIN
 SET errno = 1;
END;

#开启事务
START TRANSACTION;
insert into users (user_name) values (‘1‘);
insert into users (user_name) values (‘2‘);
SELECT errno;
select * from users;

#errno为1,事务回滚sql
IF errno=1 THEN
ROLLBACK;
ELSE
COMMIT;
END IF;
END;

call inserOrUpdate();

时间: 2024-12-10 20:22:06

PHP 事务回滚实例的相关文章

Spring中@Transactional事务回滚实例及源码

一.使用场景举例 在了解@Transactional怎么用之前我们必须要先知道@Transactional有什么用.下面举个栗子:比如一个部门里面有很多成员,这两者分别保存在部门表和成员表里面,在删除某个部门的时候,假设我们默认删除对应的成员.但是在执行的时候可能会出现这种情况,我们先删除部门,再删除成员,但是部门删除成功了,删除成员的时候出异常了.这时候我们希望如果成员删除失败了,之前删除的部门也取消删除.这种场景就可以使用@Transactional事物回滚. 二.checked异常和unc

thinkphp 的事务回滚处理 和 原始PHP的事务回滚实例

1.  要程序里面支持事务,首先连接的数据库和数据表必须支持事务 mysql   为例: 数据库InnoDB支持 transactions 数据表支持事务:InnoDB  支持transaction 2. 框架thinkphp  支持事务代码 public function testrollback(){ $model1 = D('item'); $model2 = D('vote'); $model1->startTrans(); $res1 = $model1->where('id = 5

sql事务(Transaction)用法介绍及回滚实例

事务是将一系列操作作为一个单元执行,要么成功,要么失败,回滚到最初状态.在事务处理术语中,事务要么提交,要么中止.若要提交事务,所有参与者都必须保证对数据的任何更改是永久的.不论系统崩溃或是发生其他无法预料的事件,更改都必须是持久的.只要有一个参与者无法做出此保证,整个事务就会失败.事务范围内的所有数据更改将回滚到特定设置点. Begin TRANSACTION 语句1; If @@error<>0 Goto error 语句2; If @@error<>0 Goto error

sql事务(Transaction)用法介绍及回滚实例_转

sql事务(Transaction)用法介绍及回滚实例 事务(Transaction)是并发控制的单位,是用户定义的一个操作序列.这些操作要么都做,要么都不做,是一个不可分割的工作单位.通过事务,SQL Server能将逻辑相关的一组操作绑定在一起,以便服务器保持数据的完整性 当对多个表进行更新的时候,某条执行失败.为了保持数据的完整性,需要使用事务回滚. 显示设置事务 代码如下 begin try   www.2cto.com begin transaction insert into shi

springmvc事务回滚失效

转载:http://blog.csdn.net/z69183787/article/details/37819831 前文提到,最新换了框架,新项目用SpringMVC + Spring JdbcTemplate.搭框架时,发现了一个事务无法正常回滚的问题,记录如下: 首先展示问题: Spring applicationContext.xml配置: [html] view plaincopy <bean id="dataSource" class="org.spring

Spring @Transactional ——事务回滚

工作原理运行配置@Transactional注解的测试类的时候,具体会发生如下步骤1)事务开始时,通过AOP机制,生成一个代理connection对象,并将其放入DataSource实例的某个与DataSourceTransactionManager相关的某处容器中.在接下来的整个事务中,客户代码都应该使用该connection连接数据库,执行所有数据库命令[不使用该connection连接数据库执行的数据库命令,在本事务回滚的时候得不到回滚]2)事务结束时,回滚在第1步骤中得到的代理conne

【Java EE 学习第19天】【使用过滤器实现全站压缩】【使用ThreadLocal模式解决跨DAO事务回滚问题】

一.使用过滤器实现全站压缩 1.目标:对网站的所有JSP页面进行页面压缩,减少用户流量的使用.但是对图片和视频不进行压缩,因为图片和视频的压缩率很小,而且处理所需要的服务器资源很大. 2.实现原理: (1)使用GZIPOutputStream工具对数据进行压缩,中间借助了ByteArrayOutputStream类进行结果的存储. (2)使用过滤器对浏览器请求进行拦截,通过自定义HttpServletResponse类(使用包装模式),重写getWriter方法,使得写出的目的地转变成ByteA

spring管理事务回滚

spring 事务回滚 1.遇到的问题 当我们一个方法里面有多个数据库保存操作的时候,中间的数据库操作发生的错误.伪代码如下: ? 1 2 3 4 5 6 7 public method() {   Dao1.save(Person1);   Dao1.save(Person2);   Dao1.save(Person2);//假如这句发生了错误,前面的两个对象会被保存到数据库中   Dao1.save(Person2); } 期待的情况:发生错误之前的所有数据库保存操作都回滚,即不保存 正常情

JDBC 事务回滚

package jdbcstu; import java.sql.Connection; import java.sql.DriverManager; import java.sql.SQLException; import java.sql.Statement; public class TransactionTest { public static void main(String[] args) { Connection conn=null; try { conn=getConnectio