mysql 事务

使用事务保证数据的完整性

事务 概念普及

概念

一组SQL语句放在同一批次执行
一个SQL语句出错,该批次内所有SQL语句取消执行

应用场景

用于处理操作量大,复杂度高的数据。比如说,在人员管理系统中,你删除一个人员,你即需要删除人员的基本资料,也要删除和该人员相关的信息,如信箱,文章等等,这样,这些数据库操作语句就构成一个事务!

注意

MySQL事务只支持的存储引擎
InnoDB
BDB

4种事务特性(ACID)

4种事务特性

原子性(Atomicity,或称不可分割性)
一个事务(transaction)中的所有操作,要么全部完成,要么全部不完成,不会结束在中间某个环节。事务在执行过程中发生错误,会被回滚(Rollback)到事务开始前的状态,就像这个事务从来没有执行过一样
一致性(Consistency)
(执行后,保持数据的一致)在事务开始之前和事务结束以后,数据库的完整性没有被破坏。这表示写入的资料必须完全符合所有的预设规则,这包含资料的精确度、串联性以及后续数据库可以自发性地完成预定的工作
隔离性(Isolation,又称独立性)
数据库允许多个并发事务同时对其数据进行读写和修改的能力,隔离性可以防止多个事务并发执行时由于交叉执行而导致数据的不一致。事务隔离级别见“5/4种隔离级别”
持久性(Durability)
事务处理结束后,对数据的修改就是永久的,即便系统故障也不会丢失

MySQL事务的默认设置

在 MySQL 命令行的默认设置下,事务都是自动提交的,即执行 SQL 语句后就会马上执行 COMMIT 操作。因此要显式地开启一个事务务须使用命令 BEGIN 或 START TRANSACTION,或者执行命令 SET AUTOCOMMIT=0,用来禁止使用当前会话的自动提交。

事务提交方式-命令

查看默认事务提交方式
select @@autocommit;
关闭自动提交事务
set @@autocommit=0;
开启自动提交事务
set @@autocommit=1;

使用事务/事务控制语句/事务处理步骤

步骤
关闭自动提交
set @@autocommit=0;
开始事务
begin;或者start transaction;
各种SQL语句
提交事务/事务确认
commit;
回滚事务到本次的初始状态
rollback;
还原MySQL的自动提交
set @@autocommit=1;

其他命令–使用保留点 SAVEPOINT

场景
savepoint 是在数据库事务处理中实现“子事务”(subtransaction),也称为嵌套事务的方法。事务可以回滚到 savepoint 而不影响 savepoint 创建前的变化, 不需要放弃整个事务
命令
SAVEPOINT identifier
RELEASE SAVEPOINT identifier
ROLLBACK TO identifier
注意:drop table会将identifier也一并删去!!!
其他命令-设置隔离级别
set transaction_isolation=’REPEATABLE-READ’;
InnoDB 存储引擎提供事务的隔离级别有READ UNCOMMITTED、READ COMMITTED、REPEATABLE READ 和 SERIALIZABLE

赞(2) 打赏
特别声明:除特殊标注,本站文章均为原创,遵循CC BY-NC 3.0,转载请注明出处。三伏磨 » mysql 事务

评论 抢沙发

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏