1,定义
数据库事务是逻辑上的一组SQL语句,组成这组操作的各个语句,执行是要么成功,要么失败
单个的sql的事务完成不了这样的需求的时候就可以主动开启事务
2,事物开启
'''
begin;
or
start transaction;
在 MySQL 命令行的默认设置下,事务都是自动提交的,即执行 SQL 语句后就会马上执行 COMMIT 操作。
因此要显式地开启一个事务务须使用命令 BEGIN 或 START TRANSACTION,或者执行命令 SET AUTOCOMMIT=0,用来禁止使用当前会话的自动提交。
'''
3,结束事务(提交or回滚)
'''
开启之后就可以写你的sql组合语句了,写完之后commit提交执行sql组合,或者使用rollback撤销sql执行也称之为回滚
'''
4 ,直接用 SET 来改变 MySQL 的自动提交模式:
'''
SET AUTOCOMMIT=0 禁止自动提交
SET AUTOCOMMIT=1 开启自动提交
'''
5, 事务控制语句:
'''
BEGIN或START TRANSACTION;显式地开启一个事务;
COMMIT;也可以使用COMMIT WORK,不过二者是等价的。COMMIT会提交事务,并使已对数据库进行的所有修改成为永久性的;
ROLLBACK;有可以使用ROLLBACK WORK,不过二者是等价的。回滚会结束用户的事务,并撤销正在进行的所有未提交的修改;
SAVEPOINT identifier;SAVEPOINT允许在事务中创建一个保存点,一个事务中可以有多个SAVEPOINT;
RELEASE SAVEPOINT identifier;删除一个事务的保存点,当没有指定的保存点时,执行该语句会抛出一个异常;
ROLLBACK TO identifier;把事务回滚到标记点;
SET TRANSACTION;用来设置事务的隔离级别。InnoDB存储引擎提供事务的隔离级别有READ UNCOMMITTED、READ COMMITTED、REPEATABLE READ和SERIALIZABLE。
'''
原文:https://www.cnblogs.com/daviddd/p/12047537.html