mysql 事务
使用事务保证数据的完整性
1 事务 概念普及
1.1 概念
一组SQL语句放在同一批次执行
一个SQL语句出错,该批次内所有SQL语句取消执行
2 应用场景
用于处理操作量大,复杂度高的数据。比如说,在人员管理系统中,你删除一个人员,你即需要删除人员的基本资料,也要删除和该人员相关的信息,如信箱,文章等等,这样,这些数据库操作语句就构成一个事务!
3 注意
MySQL事务只支持的存储引擎
InnoDB
BDB
4 4种事务特性(ACID)
4.1 4种事务特性
原子性(Atomicity,或称不可分割性)
一个事务(transaction)中的所有操作,要么全部完成,要么全部不完成,不会结束在中间某个环节。事务在执行过程中发生错误,会被回滚(Rollback)到事务开始前的状态,就像这个事务从来没有执行过一样
一致性(Consistency)
(执行后,保持数据的一致)在事务开始之前和事务结束以后,数据库的完整性没有被破坏。这表示写入的资料必须完全符合所有的预设规则,这包含资料的精确度、串联性以及后续数据库可以自发性地完成预定的工作
隔离性(Isolation,又称独立性)
数据库允许多个并发事务同时对其数据进行读写和修改的能力,隔离性可以防止多个事务并发执行时由于交叉执行而导致数据的不一致。事务隔离级别见“5/4种隔离级别”
持久性(Durability)
事务处理结束后,对数据的修改就是永久的,即便系统故障也不会丢失
4.2 MySQL事务的默认设置
在 MySQL 命令行的默认设置下,事务都是自动提交的,即执行 SQL 语句后就会马上执行 COMMIT 操作。因此要显式地开启一个事务务须使用命令 BEGIN 或 START TRANSACTION,或者执行命令 SET AUTOCOMMIT=0,用来禁止使用当前会话的自动提交。
4.3 事务提交方式-命令
查看默认事务提交方式
select @@autocommit;
关闭自动提交事务
set @@autocommit=0;
开启自动提交事务
set @@autocommit=1;
4.4 使用事务/事务控制语句/事务处理步骤
步骤
关闭自动提交
set @@autocommit=0;
开始事务
begin;或者start transaction;
各种SQL语句
提交事务/事务确认
commit;
回滚事务到本次的初始状态
rollback;
还原MySQL的自动提交
set @@autocommit=1;
4.5 其他命令–使用保留点 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