MySQL的事务使用

文章目录

特点

事务的基本属性ACID:

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

原子性(Atomicity):

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

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

一致性(Consistency):

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

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

隔离性(Isolation):

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

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

持久性(Durability):

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

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

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

JDBC使用事务

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

通过事务 保证了一致性

相关推荐
2301_764150565 小时前
Redis如何控制只读从库的安全_配置replica-read-only防止从节点数据被意外篡改
jvm·数据库·python
DaqunChen5 小时前
SQL如何检测分组内是否存在满足条件的数据_EXISTS结合分组
jvm·数据库·python
脑子加油站5 小时前
OpenEuler24.03 分布式配置redis 集群
数据库·redis·分布式·php·nginx代理
2301_803538955 小时前
Bootstrap 5栅格系统的五列等分布局方案
jvm·数据库·python
粉嘟小飞妹儿5 小时前
如何用 error 事件全局捕获页面图片或脚本加载失败状态
jvm·数据库·python
2301_815279525 小时前
如何在导航栏中实现左右两端对齐的菜单项布局
jvm·数据库·python
船长Talk5 小时前
SQL聚合函数与分组统计:数据分析核心技能
mysql
战族狼魂5 小时前
40x40 矩阵控制系统
jvm·oracle·矩阵
专注VB编程开发20年5 小时前
VBA/VB6 ADO数据库查询jet+只读更快
开发语言·数据库·ado·vb
Wyz201210245 小时前
宝塔面板安装后显示无法连接数据库_检查MySQL服务状态
jvm·数据库·python