事务的定义
一个最小的不可再分的工作单元
事务的四大特性(ACID)
- 原子性 事务是一个不可分割的工作单位,要么同时成功,要么同时失败。
- 隔离性 多个事务之间相互隔离的,互不干扰
- 一致性 事务执行接收之后,数据库完整性不被破坏
- 持久性 一旦事务提交,他对数据库的改变就是永久的
事务的隔离级别
- 读未提交内容(read-uncommitted)
- 多个事务同时开始,可以读到其他事务没有提交的内容
- 读取提交内容(read-committed)
- 多个事务同时开始,后提交的事务能够读到之前事务中提交的内容
- 可重复读(repeatable-read)—默认隔离级别–采用多版本并发控制实现(MVVC)
- 多个事务同时开始,后提交的事务不能够读到之前事务中提交的内容
- 可串行化(serializable)
- 多个事务同时开始,在事务A修改了数据,而没有提交数据时,此时事务B想增加或修改数据时,只能等待事务A的提交,事务B才能够执行
事务操作
# 开始事务
start transaction
# 事务提交
commit
# 事务回滚
rollback
# 设置事务是否自动提交默认自动提交(没有显示使用start transaction开始事务的时候)
set autocommit = 0;#否
set autocommit = 1;#是
注释:事务对性能的影响参考链接 mysql事务对大批量插入数据的影响