MySQL数据库事务及并发问题的解决

常见的关系型数据库有MySQL、Oracle、SQLServer等,其中MySQL成为目前互联网企业应用的主流数据库,其自身具有性能出色、适应所有平台、价格便宜、开源等优点,当前互联网技术发展有个整体的趋势,就是开源产品成为主流,很多互联网公司逐步实施去O(Oracle)化。接下来小编对数据库事务以及并发问题的解决进行分析和总结:

预计阅读时间:5分钟

什么是事务

事务是一条或多条数据库操作语句的组合,具备ACID,4个特点。

  • 原子性:要不全部成功,要不全部撤销
  • 一致性:数据库正确地改变状态后,数据库的一致性约束没有被破坏
  • 隔离性:事务之间相互独立,互不干扰
  • 持久性:事务的提交结果,将持久保存在数据库中

事务并发会产生什么问题

  • 脏读:脏读就是指当一个事务正在访问数据,并且对数据进行了修改,而这种修改还没有提交到数据库中,这时,另外一个事务也访问这个数据,然后使用了这个数据。
  • 不可重复读:是指在一个事务内,多次读同一数据。在这个事务还没有结束时,另外一个事务也访问该同一数据。那么,在第一个事务中的两次读数据之间,由于第二个事务的修改,那么第一个事务两次读到的的数据可能是不一样的。这样就发生了在一个事务内两次读到的数据是不一样的,因此称为是不可重复读。
  • 幻读:是指当事务不是独立执行时发生的一种现象,例如第一个事务对一个表中的数据进行了修改,这种修改涉及到表中的全部数据行。同时,第二个事务也修改这个表中的数据,这种修改是向表中插入一行新数据。那么,以后就会发生操作第一个事务的用户发现表中还有没有修改的数据行,就好象发生了幻觉一样。

事务隔离级别,解决什么并发问题,以及存在什么并发问题

  • READ_UNCOMMITTED
      这是事务最低的隔离级别,它充许另外一个事务可以看到这个事务未提交的数据。
      解决第一类丢失更新的问题,但是会出现脏读、不可重复读、幻读、第二类丢失更新的问题。

  • READ_COMMITTED
      保证一个事务修改的数据提交后才能被另外一个事务读取,即另外一个事务不能读取该事务未提交的数据。
      解决第一类丢失更新和脏读的问题,但会出现不可重复读、幻读、第二类丢失更新的问题

  • REPEATABLE_READ
      保证一个事务相同条件下前后两次获取的数据是一致的
    解决第一类丢失更新,脏读、不可重复读、第二类丢失更新的问题,但会出幻读。

  • SERIALIZABLE
      事务被处理为顺序执行,解决所有问题。

如何解决脏读、不可重复读和幻读问题

  • 脏读:修改时加排他锁,直到事务提交后才释放,读取时加共享锁,读取完释放事务1读取数据时加上共享锁后(这样在事务1读取数据的过程中,其他事务就不会修改该数据),不允许任何事物操作该数据,只能读取,之后1如果有更新操作,那么会转换为排他锁,其他事务更无权参与进来读写,这样就防止了脏读问题。

  • 不可重复读:读取数据时加共享锁,写数据时加排他锁,都是事务提交才释放锁。读取时候不允许其他事物修改该数据,不管数据在事务过程中读取多少次,数据都是一致的,避免了不可重复读问题

  • 幻读问题:采用Gap Lock模式,锁定检索范围为只读,这样就避免了幻读。

尾注:更多及时干货,请关注微信公众号:JAVA万维猿圈
MySQL数据库事务及并发问题的解决_第1张图片

你可能感兴趣的:(数据库)