mysql管理事务处理

这篇博客介绍了MySQL中的事务处理,强调了事务处理对于数据库完整性的关键作用。内容涵盖事务处理的基本术语,如开始事务、提交、回滚以及保留点的使用。还提到了InnoDB引擎对事务的支持,并提醒注意不能对CREATE或DROP操作进行回滚。此外,博客还讨论了如何更改默认的自动提交行为。
摘要由CSDN通过智能技术生成

并非所有引擎都支持事务处理,MyISAM不支持,InnoDB支持,创建表时要注意

事务处理可以用来维护数据库的完整性,保证mysql操作要么完全执行,要么完全不执行

利用事务处理,如果没发生错误,整租语句提交给数据库。如发生错误,则进行回退恢复数据库到某个已知的安全状态。

事务处理需要知道的几个术语:

事务:指一组sql语句
回退:指撤销指定sql语句的过程
提交:指将未存储的sql语句结果写入数据库表
保留点:指事务处理中设置的临时占位符(place - holder),你可以对它发布回退(与回退整个事务处理不同)

控制事务处理

管理事务处理的关键在于将sql语句组分解为逻辑块,并规定何时回退 或 不回退。

start transaction 标识事务开始, rollback 回退sql语句

 		select * from table;
		start transaction;  -- 标识事务的开始
		delete from table;
		select * from table;
		rollback;  -- 回退mysql语句
		select * from table;

这例子从显示table表内容开始。 首先执行一条select已显示该表不为空,然后开始一个事务处理,再用delete删除表数据,再用select去验证table表为空,这时用 rollback 语句回退 start transaction 之后的所有语句。 所以最后一条select应该不为空。

rollback 只能在一个事务处理内使用,在执行一条 start transaction 命令之后

注意: 不能回退 create 或 drop 操作

使用commit

在事务处理块中,提交不会隐含进行,需要使用 commit 明确提交

start transaction;  -- 事务开始
delete from cf where id = 2;
delete from sf where id = 3;
commit; -- 提交

最后的commit 语句仅在不出错时写出更改,如果第一条delete成功,第二天失败,则delete不会提交

隐含事务关闭:当 commit 或 rollback 语句执行后,事务会自动关闭,将来的更改会隐含提交

使用保留点

复杂的事务处理可能需要部分提交或回退

为了支持回退部分事务处理,必须能在事务处理中合适的位置放置占位符。这样可以回退到某个占位符。 这些占位符称为 保留点。

savepoint name2  -- 创建占位符,每个保留点名字都不一样,以便能明确回退到指定点
rollback to name2  -- 回退到指定保留点

保留点越多越好,因为能更灵活的进行回退
保留点在事务处理后自动释放。也可以用 release savepoint 明确释放保留点

更改默认的提交行为

mysql是自动提交更改,但可以修改

set autocommit  = 0;   

autocommit 标志决定是否自动提交更改,0 为假,1为真

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值