zoukankan      html  css  js  c++  java
  • 数据库事务特性及事务隔离级别

    一、数据库事务基本知识

    1.数据库事务:要么全部成功,要么全部失败。

    2.数据库事务特性:原子性(Atomic)、一致性(Consistency)、隔离性(Isolation)、持久性(Durabiliy)。简称ACID。

    原子性:组成一个事务的多个数据库操作是一个不可分割的原子单元,只有所有操作都成功,整个事务才会提交。任何一个操作失败,已经执行的任何操作都必须撤销,让数据库返回初始状态。

    一致性:事务操作成功后,数据库所处的状态和它的业务规则是一致的。即数据不会被破坏。如A转账100元给B,不管操作是否成功,A和B的账户总额是不变的。

    隔离性:在并发数据操作时,不同的事务拥有各自的数据空间,它们的操作不会对彼此产生干扰

    持久性:一旦事务提交成功,事务中的所有操作都必须持久化到数据库中。

    3.数据库管理系统采用数据库锁机制来保证事务的隔离性。(类似于java程序采用对象锁机制进行线程同步)

    当多个事务试图对相同数据进行操作时,只有持有锁的事务才能操作数据。

    Oracle数据库还采用了数据版本机制,为每个变化保存一个版本。

    二、数据并发问题

    数据库中的数据可能同时被多个事务访问,如果没有采取必要的隔离措施,就会导致各种并发问题,破坏数据的完整性。

    1.脏读:A事务读取B事务尚未提交的更改数据,并在这个数据的基础上进行操作。如果恰巧B事务回滚,那么A事务读取到的数据是根本不被承认的。

    2.不可重复读:A事务读取了B事务已经提交的更改数据。

    3.幻读:A事务读取了B事务已经提交的新增数据。

    4.第一类丢失更新。A事务撤销时,把已经提交的B事务的更新数据覆盖了

    5.第二类丢失更新。A事务覆盖B事务已经提交的数据,造成B事务所做的操作丢失。

     操作示例:https://juejin.im/post/5d8b2a9c518825091471fe2c

    三、事务隔离级别

    事务隔离级别:READ_UNCOMMITED、READ_COMMITTED、REPEATABLE_READ、SERIALIZABLE

    不同的事务隔离级别会导致不同的并发问题。

     一般来说,READ_UNCOMMITED拥有最高的并发量和吞吐量。而SERIALIZABLE的并发性最低。。

     

    参考自《spring 4.x--企业应用开发实战》

  • 相关阅读:
    Mysql的联合索引-最左匹配的隐藏规则
    C#读取word文档内容
    安装完office后 在组件服务里DCOM配置中找不到的解决方案
    .NET Web应用程序发布后无法读取Word文档的解决方法
    web程序读取word报异常:COM 类工厂中 CLSID 为 {000209FF-0000-0000-C000-000000000046} 的组件失败,原因是出现以下错误: 80070005 拒绝访问。最新解决方案
    C# 读取txt格式文件内容
    idea 社区版开发 springbook及问题
    Visualvm jvisualvm1.8详情使用
    VSCODE 打造完美java开发环境(新)
    如何将sdk的jar包安装到本地maven库中
  • 原文地址:https://www.cnblogs.com/expiator/p/9626123.html
Copyright © 2011-2022 走看看