【MySQL必知必会】第26章 管理事务处理(学习笔记)

事务处理用于维护数据库的完整性,确保SQL操作批量执行或全不执行。通过starttransaction开始事务,rollback回退指定操作,commit提交改动。保留点允许在事务中设置临时点进行灵活回滚,而setautocommit可更改默认的提交行为。
摘要由CSDN通过智能技术生成

事务处理

  1. 事务处理(transaction processing)可以用来维护数据库的完整性,它保证成批的MySQL操作要么完全执行,要么完全不执行
  2. 事务(transaction)指一组SQL语句
  3. 回退(rollback)指撤销指定SQL语句的过程
  4. 提交(commit)指将未存储的SQL语句结果写入数据库表
  5. 保留点(savepoint)指事务处理中设置的临时占位符(placeholder),可以对它发布回退

控制事务处理

  1. 使用语句start transaction标识事务的开始

  2. 使用rollback:

select * from ordertotals;

start transaction;

delete from ordertotals;

select * from ordertotals;

rollback;

select * from ordertotals;

使用commit

  1. 一般的MySQL语句都是直接针对数据库表执行和编写的,这就是所谓的隐含提交(implicit commit),即提交写或保存操作是自动进行的
  2. 但是,在事务处理块中 提交不会隐含地进行。为进行明确的提交,使用commit语句
  3. 隐含事务关闭,当commit或rollback语句执行后,事务会自动关闭

start transaction ;

delete from table.where sid = 1;

commit;

使用保留点

  1. 为了支持回退不分手事务处理,必须能在事务处理块中合适的位置放置占位符
  2. savepoint delete1;
  3. rollback to delete1;
  4. 保留点越多越好,因为保留点越多,你就越能按自己的意愿灵活地进行回退
  5. 释放保留点 保留点在事务处理完成后自动释放,也可用release savepoint明确地释放保留点
  6. 更改默认的提交行为,set autocommit = 0(假),不自动提交

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值