MySQL的事务使用

文章目录

特点

事务的基本属性ACID:

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

原子性(Atomicity):

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

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

一致性(Consistency):

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

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

隔离性(Isolation):

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

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

持久性(Durability):

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

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

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

JDBC使用事务

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

通过事务 保证了一致性

相关推荐
渣波15 分钟前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
Jim60018 小时前
【吃透 MySQL InnoDB连载】第 1 章・解密线上数据库高频故障
mysql
GreatSQL1 天前
gt-checksum v4.0.0 新功能解读系列文章(4):SSL 加密连接——数据校验传输安全再升级
mysql
倔强的石头_1 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
倔强的石头_4 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
云技纵横4 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
沉默王二4 天前
面试官:RAG 不用向量数据库,用 MySQL 硬扛?我:100 万向量不是很轻松?
mysql·面试·ai编程
冬奇Lab4 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
小猿姐5 天前
MySQL Top 10 热点问题 AI 运维实战:从内核诊断到云原生运维
mysql·云原生·aiops