码农知识堂 - 1000bd
Python
PHP
JS/TS
JAVA
C/C++
C#
GO
Kotlin
Swift
Spring事务管理
认识事务
可以把一系列(多条sql语句)要执行的操作称为事务,而事务管理就是管理这些操作要么
完全执行
,
要么完全不执行
(很经典的一个例子是:A要给B转钱,首先A的钱减少了,但是突然的数据库断电了,导致无法给B加钱,然后由于丢失数据,B不承认收到A的钱;在这里事务就是确保加钱和减钱两个都完全执行或完全不执行,如果加钱失败,那么不会发生减钱)。
事务管理的意义:
保证数据操作的完整性和安全性。
事务管理的四大特性: - 记住 - ACID
原子性:事务的整个操作是一个整体,不可以分割,要么全部成功,要么全部失败。
一致性:事务操作的前后,数据表中的数据没有变化。
隔离性:事务操作是相互隔离不受影响的。
持久性:数据一旦提交,不可改变,永久的改变数据表数据。
事务管理操作:
开启事务管理
:开启之后,下面的sql语句并不会马上执行并把结果写到表中,而是会写到事务日志中。
start transaction;
回滚操作
:会清掉开始事务管理之后写到事务日志中的内容,即恢复到开启事务管理之前。
语法:
rollback
; - 如果程序发生了异常,将数据恢复到没有操作之前的那个状态。
注意:回滚操作只是回退"写"的内容,对于普通的读表select语句不能回退。
事务提交
:将sql语句的结果写到数据表中。
语法:
commit
: - 持久化的保存
当 commit 或 rollback 语句执行后,事务会自动关闭
Spring事务管理机制
Spring事务管理 由三个接口共同完成 :
lPlatformTransactionManager 平台相关事务管理器 - 事务管理器
lTransactionDefinition 事务定义信息 (通过配置如何进行事务管理:隔离、传播、超时、只读)
lTransactionStatus 事务状态 (事务管理过程中,每个时间点
相关阅读:
利用 Pandoc 将 Latex 转为 MS word 的方法
用 SQL 找出某只股票连续上涨的最长天数
FPGA 20个例程篇:11.USB2.0接收并回复CRC16位校验
221114-华中科技大学学位论文利用Pandoc实现LaTex转Word
LeetCode HOT 100 —— 102.二叉树的层序遍历
「学习笔记」vector
面试-算法篇
axios 取消请求:CancelToken
达梦数据库-日期类型常用函数汇总
wsl中的ubuntu安装docker踩坑记
原文地址:https://blog.csdn.net/m0_73030012/article/details/127870487
最新文章
攻防演习之三天拿下官网站群
数据安全治理学习——前期安全规划和安全管理体系建设
企业安全 | 企业内一次钓鱼演练准备过程
内网渗透测试 | Kerberos协议及其部分攻击手法
0day的产生 | 不懂代码的"代码审计"
安装scrcpy-client模块av模块异常,环境问题解决方案
leetcode hot100【LeetCode 279. 完全平方数】java实现
OpenWrt下安装Mosquitto
AnatoMask论文汇总
【AI日记】24.11.01 LangChain、openai api和github copilot
热门文章
十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
奉劝各位学弟学妹们,该打造你的技术影响力了!
五年了,我在 CSDN 的两个一百万。
Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
面试官都震惊,你这网络基础可以啊!
你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
心情不好的时候,用 Python 画棵樱花树送给自己吧
通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
13 万字 C 语言从入门到精通保姆级教程2021 年版
10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系
2656653265@qq.com
京ICP备2022015340号-1
正则表达式工具
cron表达式工具
密码生成工具
京公网安备 11010502049817号