MySQL的事务使用

文章目录

特点

事务的基本属性ACID:

数据库事务的ACID特性是指保证数据库在执行事务操作时能够可靠和正确的四个基本属性。ACID是原子性 (Atomicity)、一致性 (Consistency)、隔离性 (Isolation)、持久性(Durability)的首字母缩写。以下是每个特性的详细解释:

原子性(Atomicity):

原子性意味着一个事务要么完全执行,要么完全不执行。在事务执行过程中,如果发生了错误或故障,已经执行的部分操作会被回滚(撤销),整个事务的操作就像从未发生过一样。

例如,在银行转账中,转账的两步(从一个账户扣款和向另一个账户存款)要么都成功,要么都不执行。不能出现只扣款但未存款的情况。

一致性(Consistency):

一致性确保事务在执行前后,数据库始终处于一致的状态。在事务开始和结束时,数据库都必须满足所有的业务规则和约束。

例如,在银行转账中,账户总金额在事务前后应保持不变。如果从一个账户扣除了金额,那么相应的金额应该加到另一个账户中,整个系统的金额总和保持一致。

隔离性(Isolation):

隔离性确保多个并发事务的执行不相互干扰。每个事务在执行过程中应该独立于其他事务的操作。事务之间的隔离级别可以通过不同的锁机制或多版本并发控制来实现。

例如,在两个并发的银行转账事务中,一个事务在执行过程中,另一个事务不应该看到其未提交的中间状态。

持久性(Durability):

持久性保证事务一旦提交,其结果会永久保存在数据库中,即使系统发生故障(如断电或崩溃),提交的事务结果也不会丢失。

例如,在银行转账中,一旦转账事务成功提交,即使系统随后发生故障,转账的结果也不会丢失,账户余额的更新会被持久保存。

这些特性共同保证了数据库在事务处理中的可靠性和一致性,确保数据的完整性和准确性。

JDBC使用事务

设计多次操作数据库的时候,下面sql是错误的。两个语句其实是需要同时执行成功或者失败的,但是现在的程序并没有按照我的要求。

通过事务 保证了一致性

相关推荐
释怀°Believe3 分钟前
javaweb
数据库·sql·oracle
Clarence Liu5 分钟前
redis学习 (1) 基础入门
数据库·redis·学习
天生励志12320 分钟前
Redis 安装部署
数据库·redis·缓存
北半球的夜21 分钟前
emoji 表情符号保存问题
数据库·oracle
清风6666661 小时前
基于单片机的智能家居多参数环境监测与联动报警系统设计
数据库·单片机·毕业设计·智能家居·课程设计·期末大作业
煎蛋学姐1 小时前
SSM社区医院儿童预防接种管理系统84ui9(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·儿童预防接种
锡兰_CC1 小时前
无缝触达,卓越体验:开启openEuler世界的任意门
服务器·网络·数据库·c++·图像处理·qt·nginx
wuxuanok1 小时前
ThinkPHP ——安装部署与配置
sql·mysql·nginx·php
ttthe_MOon2 小时前
MySQL 高可用解决方案 MHA:原理、配置与实践
数据库·mysql
一 乐2 小时前
高校评教|基于SpringBoot+vue高校学生评教系统 (源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·学习