【黑马JavaWeb+AI知识梳理】Web后端开发02-事务管理、文件上传

事务管理

  • 介绍&操作

    • 事务是一组操作的集合 ,它是一个不可分割的工作单位。事务会把所有的操作作为一个整体一起向系统提交或撤销操作请求,即这些操作要么同时成功,要么同时失败

    • 事务控制主要三步操作:开启事务提交 事务/回滚事务

      • start transaction; / begin;

      • commit;(全部成功)

      • rollback;(只要有一项失败)

    • 应用场景:

      • 银行转账

      • 下单扣减库存

  • Spring事务管理

    • @Transactional //事务管理 - 默认出现运行时异常,才会回滚,即RuntimeException

    • 将当前方法交给spring进行事务管理,方法执行前,开启事务;成功执行完毕,提交事务;出现异常,回滚事务

    • 位置:业务(service)层的方法(推荐在会对数据库操作多次的方法)上、类上、接口上

  • 事务进阶-rollbackFor

    • 用于控制出现何种异常类型,回滚事务
  • 事务进阶-propagation

    • 事务传播行为:

      • 指的就是当一个事务方法被另一个事务方法调用时,这个事务方法应该如何进行事务控制
    • Required:大部分场景

    • Requires_New:希望两个方法在独立的事务中运行,互不影响

  • 四大特性(ACID)

    • 原子性(Atomicity)

      • 不可分割的最小单元,要么全部成功,要么全部失败
    • 一致性(Consistency)

      • 事务完成时,必须使所有的数据都保持一致状态
    • 持久性(Isolation)

      • 数据库系统提供的隔离机制,保证事务在不受 外部并发操作影响的独立环境下运行
    • 隔离性(Durability)

      • 事务一旦提交或回滚,它对数据库中数据的改变就是永久的
相关推荐
安当加密1 天前
MySQL 数据库如何加密脱敏?TDE透明加密 + DBG数据库网关 双引擎加固实战
数据库·mysql·adb
半桶水专家1 天前
go语言中的结构体嵌入详解
开发语言·后端·golang
IT技术分享社区1 天前
MySQL统计查询优化:内存临时表的正确打开方式
数据库·mysql·程序员
短剑重铸之日1 天前
7天读懂MySQL|Day 5:执行引擎与SQL优化
java·数据库·sql·mysql·架构
好记忆不如烂笔头abc1 天前
RECOVER STANDBY DATABASE FROM SERVICE xxx,ORA-19909
数据库
writeone1 天前
数据库习题
数据库
廋到被风吹走1 天前
【数据库】【Oracle】分析函数与窗口函数
数据库·oracle
佳佳_1 天前
关于在 Fabric.js 中注册字体覆盖的问题
后端·node.js
陌北v11 天前
为什么我从 MySQL 迁移到 PostgreSQL
数据库·mysql·postgresql
GoGeekBaird1 天前
通过ChatGPT+Nano Banana定制一个 PPT 生成的工作流
后端