MySQL-InnoDB事务

事务的定义

一个最小的不可再分的工作单元

事务的四大特性(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事务对大批量插入数据的影响

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值