分布式事务实战(二) -事务基本概念

Lacie ·
更新时间:2024-09-21
· 903 次阅读

1 什么是事务

一种可靠、一致的方式,访问和操作数据库中数据的程序单元。

2 ACID性质

并非任意的对数据库的操作序列都是数据库事务。数据库事务拥有以下四个特性,习惯上被称之为ACID特性。

原子性(Atomicity):事务作为一个整体被执行,包含在其中的对数据库的操作要么全部被执行,要么都不执行 一致性(Consistency):事务应确保数据库的状态从一个一致状态转变为另一个一致状态。一致状态的含义是数据库中的数据应满足完整性约束 隔离性(Isolation):多个事务并发执行时,一个事务的执行不应影响其他事务的执行 持久性(Durability):已被提交的事务对数据库的修改应该永久保存在数据库中 3 案例

某人要在商店使用电子货币购买100元的东西,当中至少包括两个操作:

该人账户减少100元 商店账户增加100元

支持事务的数据库管理系统(transactional DBMS)就是要确保以上两个操作(整个“事务”)都能完成,或一起取消;否则就会出现100元平白消失或出现的情况。

但在现实情况下,失败的风险很高。在一个数据库事务的执行过程中,有可能会遇上事务操作失败、数据库系统/操作系统出错,甚至是存储介质出错等情况。这便需要DBMS对一个执行失败的事务执行恢复操作,将其数据库状态恢复到一致状态(数据的一致性得到保证的状态)。为了实现将数据库状态恢复到一致状态的功能,DBMS通常需要维护事务日志以追踪事务中所有影响数据库数据的操作。

4 MySQL 事务操作的 SQL BEGIN TRANSACTION; UPDATE t user SET amount = amount-100 WHERE username = 'Java'; UPDATE t user SET amount = amount+ 100 WHERE username = 'Edge'; COMMIT -- ROLL BACK

那么问题来了,Java中如何实现操作呢?

JDBC事务管理流程
Connection conn = getConnection(); conn.setAutoCommit(false); Statement stmt1 = conn. prepareStatement(updateUser1SQL); stmt1.executeUpdate(); Statement stmt2 = conn.prepareStatement(updateUser2SQL); stmt2.executeUpdate(); conn.commit(); // or conn.rollback (); 事务的提交/回滚

查看MySQL的事务隔离级别

SELECT @@GLOBAL.tx_ isolation, @@tx_isolation; 参考 数据库事务
作者:Java爱好者哦



实战 分布式事务 分布式 分布 事务

需要 登录 后方可回复, 如果你还没有账号请 注册新账号