Java核心-事务

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: Java核心-事务

事务

事务指的是逻辑上的一组操作,组成这个操作的各个单元,要么都成功,要么都不成功

例如A给B转账,这个业务包含两个步骤

  • 给A的账户扣钱
  • 给B的账户加钱

组成这个业务的这两个步骤,要么就都成功,要么就都不成功。

事务的使用

事务相关的API

//开启事务
connection.setAutoCommit(false);
//具体执行步骤
//提交事务
connection.commit();
//回滚事务
connection.rollback();

转账的案例的具体实现:

public static Boolean transfer(String fromName, String toName, Integer money) {
        //获取连接
        Connection connection = JDBCUtils.getConnection();
        //开启事务
        try {
            connection.setAutoCommit(false);
        } catch (SQLException e) {
            e.printStackTrace();
        }
        try {
            //执行步骤
            //给from的扣钱
            PreparedStatement preparedStatement = connection.prepareStatement("update account set money = money-? " +
                    "where " +
                    "name = ?");
            preparedStatement.setInt(1, money);
            preparedStatement.setString(2, fromName);
            //执行
            int affectRows = preparedStatement.executeUpdate();
            if (affectRows != 1) {
                System.out.println("扣钱失败!!!");
                return false;
            }
            //给toName加钱
            preparedStatement.setInt(1, (-money));
            preparedStatement.setString(2, toName);
            int affectRows1 = preparedStatement.executeUpdate();
            if (affectRows1 != 1) {
                System.out.println("加钱失败!!!");
                return false;
            } else {
                //执行到这里说明扣钱和加钱都成功了,提交事务
                connection.commit();
                return true;
            }
        } catch (Exception e) {
            //如果出现异常,就要回滚事务
            try {
                connection.rollback();
            } catch (SQLException e1) {
                e1.printStackTrace();
            }
            System.out.println("回滚成功");
        }
        return false;
    }

事务的四个特性

ACID

  • 原子性(A)
    事务是不可分割的工作单位,事务中的操作要么都发生,要么都不发生
  • 一致性©
    一致性指的是事务必须使数据库的一个一致性状态到另一个一致性状态;保证数据的整体一致性
  • 隔离性(I)
    事务与事务之间应该互不影响
  • 持久性(D)
    事务一旦提交,对数据库的改变是永久性的

事务的隔离级别

事务与事务之间有不同的隔离级别,对事务间的隔离有不同的结果

如果是多线程并发访问共同数据的时候,会存在以下问题:

  • 脏读
    脏读是指一个事务读取到了另一个事务还没有提交的数据
  • 不可重复读
    同一份数据在同一个事务中读取的结果前后不一致。实际上是一个事务读取到了另一个事务已经提交的数据
  • 虚幻读
    在同一个事务中,有些记录有时候能读到,有时候读不到,常见于执行插入和删除操作的时候

MySQL中有以下隔离级别

  • read uncommitted 读未提交
  • read committed 读已提交
  • repeatable read 可重复读(MySQL默认的隔离级别)
  • serializable 串行化

在cmd中查看数据库的隔离级别的方法

-- 查看数据库的隔离级别
select @@tx_isolation;
-- 修改数据库的隔离级别
set global transaction isolation level xxx;
-- 修改完了之后需要重新建立连接

读未提交

read uncommitted:指一个事务可以读取到另一个事务未提交的数据

存在如下问题:脏读、不可重复读、虚幻读

读已提交

read committed:指一个事务只能读取到另一个事务已提交的数据

存在的问题:不可重复读、虚幻读

可重复读

repeatable read 可重复读(MySQL默认的隔离级别):相当于一个事务只会读取到事务开启时的数据,无论其他事务做什么操作,都不会更改;

MySQL的存储引擎InnoDB解决了虚幻读的问题

串行化

serializable 串行化:让事务串行执行,相当于单线程,不能并发

一个事务必须等待其他事务执行,这样没有安全隐患

存在的问题:效率低

脏读 不可重复读 虚幻读
read uncommitted
read committed X
repeatable read X X X
serializable X X X

安全性越高,效率越低

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
8月前
|
Java Spring
Java事务&事务失效场景
Java事务&事务失效场景
134 0
|
5月前
|
负载均衡 NoSQL 算法
一天五道Java面试题----第十天(简述Redis事务实现--------->负载均衡算法、类型)
这篇文章是关于Java面试中Redis相关问题的笔记,包括Redis事务实现、集群方案、主从复制原理、CAP和BASE理论以及负载均衡算法和类型。
一天五道Java面试题----第十天(简述Redis事务实现--------->负载均衡算法、类型)
|
5月前
|
安全 Java 数据库
一天十道Java面试题----第四天(线程池复用的原理------>spring事务的实现方式原理以及隔离级别)
这篇文章是关于Java面试题的笔记,涵盖了线程池复用原理、Spring框架基础、AOP和IOC概念、Bean生命周期和作用域、单例Bean的线程安全性、Spring中使用的设计模式、以及Spring事务的实现方式和隔离级别等知识点。
|
3月前
|
消息中间件 分布式计算 Java
大数据-73 Kafka 高级特性 稳定性-事务 相关配置 事务操作Java 幂等性 仅一次发送
大数据-73 Kafka 高级特性 稳定性-事务 相关配置 事务操作Java 幂等性 仅一次发送
41 2
|
5月前
|
小程序 Java 开发工具
【Java】@Transactional事务套着ReentrantLock锁,锁竟然失效超卖了
本文通过一个生动的例子,探讨了Java中加锁仍可能出现超卖问题的原因及解决方案。作者“JavaDog程序狗”通过模拟空调租赁场景,详细解析了超卖现象及其背后的多线程并发问题。文章介绍了四种解决超卖的方法:乐观锁、悲观锁、分布式锁以及代码级锁,并重点讨论了ReentrantLock的使用。此外,还分析了事务套锁失效的原因及解决办法,强调了事务边界的重要性。
146 2
【Java】@Transactional事务套着ReentrantLock锁,锁竟然失效超卖了
|
5月前
|
前端开发 Java 数据库连接
一天十道Java面试题----第五天(spring的事务传播机制------>mybatis的优缺点)
这篇文章总结了Java面试中的十个问题,包括Spring事务传播机制、Spring事务失效条件、Bean自动装配方式、Spring、Spring MVC和Spring Boot的区别、Spring MVC的工作流程和主要组件、Spring Boot的自动配置原理和Starter概念、嵌入式服务器的使用原因,以及MyBatis的优缺点。
|
5月前
|
算法 关系型数据库 MySQL
一天五道Java面试题----第七天(mysql索引结构,各自的优劣--------->事务的基本特性和隔离级别)
这篇文章是关于MySQL的面试题总结,包括索引结构的优劣、索引设计原则、MySQL锁的类型、执行计划的解读以及事务的基本特性和隔离级别。
|
7月前
|
Java 测试技术 数据库连接
解密Java事务传播行为与隔离级别:案例详解与解决方案
解密Java事务传播行为与隔离级别:案例详解与解决方案
71 1
|
7月前
|
Java Spring
Java事务的传播
Java事务的传播
32 0
|
7月前
|
SQL Java 关系型数据库
JAVA数据库开发 - 事务
JAVA数据库开发 - 事务
46 0