zoukankan      html  css  js  c++  java
  • 数据库中事务详解!

    首先说一下什么是事务!

    数据库事务(Database Transaction) ,是指作为单个逻辑工作单元执行的一系列操作,要么完全地执行,要么完全地不执行。 事务处理可以确保除非事务性单元内的所有操作都成功完成,否则不会永久更新面向数据的资源。通过将一组相关操作组合为一个要么全部成功要么全部失败的单元,可以简化错误恢复并使应用程序更加可靠。一个逻辑工作单元要成为事务,必须满足所谓的ACID(原子性、一致性、隔离性和持久性)属性。事务是数据库运行中的逻辑工作单位,由DBMS中的事务管理子系统负责事务的处理。

    来自百度百科!

    再说一下事务的四大特性:

    1. 原子性(Atomicity)
                                  原子性是指事务包含的所有操作要么全部成功,要么全部回滚,因此事务的操作成功就必须要完全应用到数据库,

                      如果操作失败则不能对数据库又热和影响

                 2.一致性(Consistency)
                                   一致性是指事务必须是数据库从一个一致性状态变换到另一个一致性状态,也就是说一个事务执行之前和执行

                      之后都必须处于一致性状态.

                                    那转账来说,假设用户A和用户B两者的钱加起来一共是5000,那么不管A还是B如何转账,转几次帐,事务结束后

                       两个用户的钱加起来应该还是5000,这就是事务的一致性.

               3.隔离性(Isolation)
                                    隔离性是当多个用户并发访问数据库时,比如操作同一张时,数据库为每一个用户开启的事务,不能被其他事务的

                       操作所干扰,多个并发事务之间要相互隔离.

                                    纪要达到这么一种效果:对于任意两个并发的事务T1和T2,在事务T1看来,T2要么在T1开始之前就已经结束,要么

                        在T1结束之后才开始,这样每个事务都感觉不到其他事务在并发的执行.

                 4.持久性(Durability)
                                    持久性是指一个事务一旦被提交了,那么对数据库中的数据改变就是永久性的,即便是在数据库系统遇到故障的情

                          况下也不会丢失提交事务的操作.

                                     列如我们在使用JDBC 操作数据库时,在提交事务方法后,提示用户事务操作完成,当我们程序执行完成直到看到提

                          示后,就可以认定事务以及正确提交,即使这时候数据库出现了问题,也必须要将我们的事务完全执行完成,否则就会造成我

                          们看到提示事务处理完毕,但是数据库因为故障而没有执行事务的重大错误!

    事务有三种模型:
    1.隐式事务是指每一条数据操作语句都自动地成为一个事务,事务的开始是隐式的,事务的结束有明确的
    标记。
    2.显式事务是指有显式的开始和结束标记的事务,每个事务都有显式的开始和结束标记。
    3.自动事务是系统自动默认的,开始和结束不用标记。
  • 相关阅读:
    std::get<C++11多线程库~线程间共享数据>(10):使用互斥量保护共享数据(5)
    std::get<C++11多线程库~线程间共享数据>(10):使用互斥量保护共享数据(4)
    C++多线程库的常用函数 std::lock()
    std::get<C++11多线程库~线程间共享数据>(10):使用互斥量保护共享数据(3)
    std::get<C++11多线程库~线程间共享数据>(10):使用互斥量保护共享数据(2)
    std::get<C++11多线程库~线程间共享数据>(10):使用互斥量保护共享数据(1)
    C++多线程库的常用模板类 std::lock_guard
    C++多线程库的常用类 std::mutex
    npm install 时,下载github的包超时解决方法
    SAP 电商云 Spartacus UI 和路由相关的 State 处理
  • 原文地址:https://www.cnblogs.com/HoneyTYX/p/10191622.html
Copyright © 2011-2022 走看看