MySQL事务基础
发布日期:2021-06-30 12:23:23
浏览次数:2
分类:技术文章
本文共 1155 字,大约阅读时间需要 3 分钟。
1 什么是事务
一种可靠、一致的
方式,访问和操作数据库中数据的程序单元。
2 ACID性质
并非任意的对数据库的操作序列都是数据库事务。数据库事务拥有以下四个特性,习惯上被称之为ACID特性。
原子性(Atomicity)
一次事务包含在其中的对数据库的操作中的操作要么全部成功,要么全部失败。
一致性(Consistency)
跨表、跨行、跨事务,数据库始终保持一致状态。
事务应确保数据库的状态从一个一致状态转变为另一个一致状态。一致状态的含义是数据库中的数据应满足完整性约束
隔离性(Isolation)
可见性,保护事务不会互相干扰, 包含4种隔离级别多个事务并发执行时,一个事务的执行不应影响其他事务的执行
持久性(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 (); 事务的提交/回滚
转载地址:https://javaedge.blog.csdn.net/article/details/104871528 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
留言是一种美德,欢迎回访!
[***.207.175.100]2024年04月27日 03时22分17秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
GlusterFS原理及如何配置使用
2021-07-03
shell之条件测试和if语句
2021-07-03
shell脚本之case-for-while-until语句
2021-07-03
shell脚本小案例之九九乘法表、幸运大抽奖、简易计算器
2021-07-03
shell脚本之函数和数组(含案例,适合新手练习)
2021-07-03
shell脚本之数组的升降序排序,插入排序
2021-07-03
shell脚本之正则表达式(grep 和 egrep命令详解)
2021-07-03
shell脚本之sed工具使用
2021-07-03
shell脚本之awk工具详解
2021-07-03
shell脚本之排序工具(sort、uniq)
2021-07-03
shell脚本之expect免交互
2021-07-03
shell编程之实战----MAC记录与端口扫描脚本、开发系统监控脚本
2021-07-03
ELK日志分析系统原理与部署
2021-07-03
Nginx访问状态以及基于多域名、多端口、多IP配置虚拟主机
2021-07-03
Nginx优化及防盗链
2021-07-03
Docker简介和安装优化
2021-07-03
Docker之镜像、容器的管理命令详解
2021-07-03
Docker-构建镜像、私有仓库registry、数据卷、端口映射、容器互联
2021-07-03
Tomcat安装部署、构建虚拟主机以及优化参数
2021-07-03
Nginx 之 Rewrite和具体场景
2021-07-03