zoukankan      html  css  js  c++  java
  • 事务相关

    事务指的是逻辑上的一组操作,这组操作要么全部成功,要么全部失败。

    事务的ACID特性:

    原子性(A):指事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生。

    一致性(C):指事务前后数据的完整性必须保持一致。

    隔离性(I):指多个用户并发访问数据库时,一个用户的事务不能被其他用户的事务所干扰,多个并发事务之间数据要相互隔离。

    持久性(D):指一个事务一旦被提交,它对数据库中数据的改变就是永久性的,即使数据库发生故障也不应该对其有任何影响。

    Spring中事务管理的API---PlatformTransactionManager,TransactionDefinition,TransactionStatus:

     不使用隔离导致的三种安全性问题:

    脏读:一个事务读取了另一个事务改写但还未提交的数据,如果这些数据被回滚,则读到的数据是无效的。

    不可重复读:在同一事务中,多次读取同一数据返回的结果有所不同。

    幻读:一个事务读取了几行记录后,另一个事务插入一些记录,幻读就发生了,在后来的查询中,第一个事务就会发现有些原来没有的记录。

    图释:

    前三个为一类,比如第一个PROPAGATION_REQUIRED,表示如果aaa中有事务,则bbb运行aaa中的事务,如果aaa中没有事务,则bbb新建一个事务,也就是说aaa和bbb在一个事务中。

    后三个为一类,比如第一个PROPAGATION_REQUIRES_NEW,表示如果aaa中有事务,则bbb将当前aaa中的事务挂起,然后自己新建一个事务,也就是说aaa和bbb不在一个事务中。

    最后一个为一类,比如在执行aaa时,就会使用事务来设置一个保存点,再去执行bbb时,如果bbb没有异常,则aaa和bbb一起提交,如果bbb有异常,会根据自己的设定(回滚到保存点,或回滚到最初状态)来执行相应操作。

  • 相关阅读:
    【原创】大数据基础之Hadoop(3)yarn数据收集与监控
    【原创】运维基础之Docker(7)关于docker latest tag
    【原创】大数据基础之ElasticSearch(4)es数据导入过程
    【原创】大叔经验分享(44)hdfs副本数量
    【转】IAR IDE for MSP430、8051、ARM等平台的结合使用
    写驱动的步骤
    【转】IAR for STM8介绍、下载、安装与注册
    KEIL中函数定义存在但go to definition却不跳转的原因
    FatFs
    学习2__STM32--汉字显示
  • 原文地址:https://www.cnblogs.com/cing/p/7458995.html
Copyright © 2011-2022 走看看