• Spring事务管理


    认识事务

    • 可以把一系列(多条sql语句)要执行的操作称为事务,而事务管理就是管理这些操作要么完全执行要么完全不执行(很经典的一个例子是:A要给B转钱,首先A的钱减少了,但是突然的数据库断电了,导致无法给B加钱,然后由于丢失数据,B不承认收到A的钱;在这里事务就是确保加钱和减钱两个都完全执行或完全不执行,如果加钱失败,那么不会发生减钱)。

    事务管理的意义:

    • 保证数据操作的完整性和安全性。

    事务管理的四大特性: - 记住 - ACID

    • 原子性:事务的整个操作是一个整体,不可以分割,要么全部成功,要么全部失败。
    • 一致性:事务操作的前后,数据表中的数据没有变化。
    • 隔离性:事务操作是相互隔离不受影响的。
    • 持久性:数据一旦提交,不可改变,永久的改变数据表数据。

    事务管理操作:

    • 开启事务管理:开启之后,下面的sql语句并不会马上执行并把结果写到表中,而是会写到事务日志中。
    • start transaction;
    • 回滚操作:会清掉开始事务管理之后写到事务日志中的内容,即恢复到开启事务管理之前。
    • 语法:rollback; - 如果程序发生了异常,将数据恢复到没有操作之前的那个状态。
    • 注意:回滚操作只是回退"写"的内容,对于普通的读表select语句不能回退。
    • 事务提交:将sql语句的结果写到数据表中。
    • 语法:commit: - 持久化的保存
    • 当 commit 或 rollback 语句执行后,事务会自动关闭

    Spring事务管理机制

    • Spring事务管理 由三个接口共同完成 :
    • lPlatformTransactionManager 平台相关事务管理器  - 事务管理器
    • lTransactionDefinition 事务定义信息 (通过配置如何进行事务管理:隔离、传播、超时、只读)
    • lTransactionStatus 事务状态 (事务管理过程中,每个时间点
  • 相关阅读:
    手把手教你用Python绘制神经网络图
    xshell 判断文件超出指定大小则清空文件
    深度学习模型的参数、计算量和推理速度统计
    计算机毕业设计之java+ssm土家风景文化管理平台-旅游景点攻略网站
    如何拉取钉钉的外出、出差审批单
    AI-新手玩转RKNN
    游戏引擎,脚本管理模块
    C++征途 --- deque容器
    算法通关村第十关-白银挑战数组最大K数
    web前端期末大作业:基于HTML+CSS+JavaScript制作我的音乐网站(带设计报告)
  • 原文地址:https://blog.csdn.net/m0_73030012/article/details/127870487