Mysql事务自我总结

事务指的是,一组业务逻辑代码在一个事务中,执行提交或者回滚,要么同时执行 要么同时不执行。在java中用try catch代码块,控制事务中业务逻辑代码,如果是正常情况会执行提交操作 数据会持久化保存到数据库中,如果出现异常也会执行回滚操作,数据是没有持久化的,仅仅是临时改变了。

事务有四大特性:原子性、一致性、持久性、隔离性

  1. 原子性:在同一个事务中的一组业务逻辑代码是不可分割的,也就是说,要么同时执行,要么同时不执行

  2. 一致性:当提交事务后,数据库中的数据总数应该保持不变,比如说转账业务中,A给B转100,A少了100,B却没有收到

  3. 持久性:当开启事务,进行业务逻辑处理,如果没有提交,数据库中的数据是不受改变的,只有提交后,才会将数据持久化,保存到我们的硬盘中

  4. 隔离性:多个事务并发访问数据库时,对于数据访问的结果,根据隔离级别的不同,可能出现多种情况

隔离级别分四种:读未提交、读已提交、可重复读、串行化

  1. 读未提交:此隔离级别会引发三种问题,最严重的问题就是脏读。当隔离级别设置成读未提交,用户访问数据库时,访问的数据是不准确的,因为别人可能会进行回滚操作,当再次访问,数据可能会改变。一般情况下,大多数业务不能出现脏读情况。

  2. 读已提交:此隔离级别会引发两种问题,最严重的是不可重复读。在同一个事务中,不可以重复读同一个数据,因为其他用户可能会对数据进行操作,多次访问的数据结果可能是不同的。这种情况对于不同需要来讲,可能是问题也可能不是问题。比如说,在年会中,领导给同事们看了今年的收益 有100个亿,可是年会快结束的时候,再看就变成了98个亿。100个亿和98个亿其实都是对于对应时间的收益额,所以对于这种业务,是不能存在不可重复读的情况。再比如说,炒股,对于股票的掌控是实时的,前一秒可能是盈利,下一秒可能就是跌股,所以说对于这种业务,数据应该是实时的,就必须是不可重复读。

  3. 可重复读:此隔离级别会引发一种问题,幻读(虚读)。同一个事务中,对一个数据进行增删操作,在操作之前却已经被其他用户删除或者添加,该用户就无法操作成功,这就是幻读,怀疑自己刚才读错了。

  4. 串行化:以上三个问题都不会发生,这是最安全的隔离级别。

    oracle、mysql两个数据库对于隔离级别的设置分别是读已提交、可重复读,都没有设置成串行化。

    随着数据越来越安全,会导致数据查询效率、增删改的效率越来越慢。越安全越慢,我们常使用arraylist集合,并不是因为他线程安全,而是因为他对数据的操作快。

    根据需要可以设置成不同的隔离级别。

    永远不可以设置串行化隔离级别,串行化这种隔离级别不能异步,只能同步。多用户不能并发访问。也就是说后一个用户需要前一个用户执行完才能进行操作。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值