MySQL中关于事务的总结

四大特征

  1. 原子性,要么同时成功,要么同时失败,是不可分割的最小单位
  2. 持久性,提交或回滚数据库会持久化保存数据
  3. 隔离性,多个事务之间,相互独立,由锁来实现
  4. 一致性,数据操作前后,总量保持不变。数据库从一个一致状态变换到另外一个一致性状态

事务有关命令

set autocommit=0

开启:start transation

回滚:rollback

提交:commit

Set @@commit 查询

Set @@commit 0代表手动提交,1代表自动提交

select @@tx_isolation查询隔离级别

Set global transaction isolation level 级别 设置

隔离级别

隔离级别

read uncommitted

read committed oracle默认

repeatable read mysql默认 解决不了幻读

serializable

隔离级别解决的对应问题

  1. 丢失更新:两个事务同时修改一个值,后面的事务会覆盖前一个事务的更新动作。

解决:对行加锁,只允许并发一个更新事务。

  1. 脏读:一个事务读到另一个事务中已修改但没有提交的数据,若另一个事务执行了撤销动作,则得到了脏数据。

解决:其他事务不能读取未完成事务中修改的值

  1. 不可重复读:同一个事务中,两次读取到的数据不一样。事务1修改数据,提交之前事务2先读取了数据,事务1提交之后事务2又读取了该数据结果两次读取的数据不一样

解决:修改事务完全提交之后才可以读取数据

  1. 幻读:事务1更新新增1条数据正好满足事务2的查询条件,而事务2重新查询相同的条件会多出一条记录

解决:其他事务在操作事务完成数据处理之前不可以添加新数据

传播行为

  1. TransactionDefinition.PROPAGATION_REQUIRED:
    如果当前存在事务,则加入该事务;如果当前没有事务,则创建一个新的事务。这是默认值。

  2. TransactionDefinition.PROPAGATION_REQUIRES_NEW:
    创建一个新的事务,如果当前存在事务,则把当前事务挂起。

  3. TransactionDefinition.PROPAGATION_SUPPORTS:
    如果当前存在事务,则加入该事务;如果当前没有事务,则以非事务的方式继续运行。

  4. TransactionDefinition.PROPAGATION_NOT_SUPPORTED:
    以非事务方式运行,如果当前存在事务,则把当前事务挂起。

  5. TransactionDefinition.PROPAGATION_NEVER:
    以非事务方式运行,如果当前存在事务,则抛出异常。

  6. TransactionDefinition.PROPAGATION_MANDATORY:
    如果当前存在事务,则加入该事务;如果当前没有事务,则抛出异常。

  7. TransactionDefinition.PROPAGATION_NESTED:
    如果当前存在事务,则创建一个事务作为当前事务的嵌套事务来运行;
    如果当前没有事务,则该取值等价于TransactionDefinition.PROPAGATION_REQUIRED。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值