JDBC Part4 Transaction 事务

什么是事务?

事务是应用程序中一系列严密的操作,所有操作必须成功完成,否则在每个操作中所作的所有更改都会被撤消。

也就是原子性,一个事务中的一系列的操作要么全部成功,要么一个都不做。

事务的结束

有两种,当事务中的所以步骤全部成功执行时,事务提交。

如果其中一个步骤失败,将发生回滚操作,撤消撤消之前到事务开始时的所以操作。

事务的 ACID
事务具有四个特征:原子性( Atomicity )、一致性( Consistency )、隔离性( Isolation )和持续性( Durability )。这四个特性简称为 ACID 特性。

1 、原子性
事务是数据库的逻辑工作单位,事务中包含的各操作要么都做,要么都不做
2 、一致性
事务执行的结果必须是使数据库从一个一致性状态变到另一个一致性状态。

因此当数据库只包含成功事务提交的结果时,就说数据库处于一致性状态。

如果数据库系统 运行中发生故障,有些事务尚未完成就被迫中断,

这些未完成事务对数据库所做的修改有一部分已写入物理数据库,这时数据库就处于一种不正确的状态,或者说是 不一致的状态。

3 、隔离性
一个事务的执行不能其它事务干扰。即一个事务内部的操作及使用的数据对其它并发事务是隔离的,并发执行的各个事务之间不能互相干扰。
4 、持续性
也称永久性,指一个事务一旦提交,它对数据库中的数据的改变就应该是永久性的。接下来的其它操作或故障不应该对其执行结果有任何影响。

数据库系统必须维护事务的以下特性 ( 简称 ACID) :
原子性 (Atomicity)
一致性 (Consistency)
隔离性 (Isolation)
持久性 (Durability)


引用自:https://blog.csdn.net/xiaoyu714543065/article/details/8211265

数据库事务:

一组逻辑操作单元,使数据从一种状态变换到另一种状态

逻辑操作单元 -> 一个或者多个的DML操作

一组连续完整的业务SQL,要么全部成功,commit提交,只要一项异常,就必须rollback回滚

自动提交的情况:

- DDL操作,一旦可以执行,自动提交 【setAutoCommit(false)是无效的】

- DML操作,一旦可以执行,自动提交 【setAutoCommit(false)可以取消】

- 关闭连接对象,自动提交事务

JDBC对事物的设置

    @Test
public void transaction() {
Connection connection = JdbcUtil.getConnection();
PreparedStatement preparedStatement = null;
try{
System.out.println(connection.getAutoCommit()); // 检查自动提交状态
connection.setAutoCommit(false); // 关闭自动提交
System.out.println(connection.getAutoCommit());
// 插入 、删除、修改、是一样的
String sql = "insert into user(user_id,user_name,user_password,user_img) values(?,?,?,?);"; InputStream inputStream = new FileInputStream(new File("scene.jpg")); preparedStatement = connection.prepareStatement(sql);
preparedStatement.setObject(1,1);
preparedStatement.setObject(2,"同调士");
preparedStatement.setObject(3,"333666");
preparedStatement.setObject(4,inputStream); int i = preparedStatement.executeUpdate();
System.out.println(i); connection.commit(); //所有操作都成功了才执行提交
}catch (Exception e){
try {
connection.rollback(); // 发生异常,回滚操作
} catch (SQLException throwables) {
throwables.printStackTrace();
}
e.printStackTrace();
} finally {
try {
// 结束连接之前,再设置为True,因为放在连接池里面多次使用,
// 要保证别的事物还是正常的自动提交
connection.setAutoCommit(true);
} catch (SQLException throwables) {
throwables.printStackTrace();
}
JdbcUtil.closeResource(connection,preparedStatement);
}
}

数据库的并发问题?

同时执行多个事务,这些事务访问了同一个数据,不采取必要的隔离机制,就会导致并发问题

- 脏读  事务A&B,A读取了已经被B更新但尚未提交的字段,如果B回滚,A读取的玩意儿就作废了!?(临时的无效的)

- 不可重复读  事务A&B,A读取了一个字段后,B更新了这个字段,A再次读取后,值不同了

- 幻读  事务A&B,A从一个表读取了一个字段,B在表中插入了新的行,A再次读取就会多出新行

隔离性原则:数据库系统必须具有隔离并发运行各个事务的能力,使他们互不影响避免并发问题

事务间的隔离成都称为隔离级别,其中有4种隔离级别,对应4种干扰程度

隔离级别越高,数据一致性越好,但是并发也越弱

详细引用:

https://www.cnblogs.com/fjdingsd/p/5273008.html

JDBC的Dao封装,具体就是一些其他东西的封装,

不算主要内容,了解一下用来对接WEB开发平滑过渡

P42 - P45

https://www.bilibili.com/video/BV1eJ411c7rf?p=42

【Java】JDBC Part4 Transaction 事务的更多相关文章

  1. JAVA JDBC(存储过程和事务管理)

    1.什么是存储过程 存储过程(Stored Procedure)是在大型数据库系统中,一组为了完成特定功能的SQL 语句集,存储在数据库中,经过第一次编译后再次调用不需要再次编译,用户通过指定存储过程 ...

  2. Java数据库连接——JDBC调用存储过程,事务管理和高级应用

    一.JDBC常用的API深入详解及存储过程的调用 相关链接:Jdbc调用存储过程 1.存储过程(Stored Procedure)的介绍 我们常用的操作数据库语言SQL语句在执行的时候需要先编译,然后 ...

  3. [原创]java WEB学习笔记77:Hibernate学习之路---Hibernate 版本 helloword 与 解析,.环境搭建,hibernate.cfg.xml文件及参数说明,持久化类,对象-关系映射文件.hbm.xml,Hibernate API (Configuration 类,SessionFactory 接口,Session 接口,Transaction(事务))

    本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...

  4. Java -- JDBC 学习--事务

    数据库事务 在数据库中,所谓事务是指一组逻辑操作单元,使数据从一种状态变换到另一种状态.为确保数据库中数据的一致性,数据的操纵应当是离散的成组的逻辑单元:当它全部完成时,数据的一致性可以保持,而当这个 ...

  5. Java操作数据库——在JDBC里使用事务

    Java操作数据库——在JDBC里使用事务 摘要:本文主要学习了如何在JDBC里使用事务. 使用Connection的事务控制方法 当JDBC程序向数据库获得一个Connection对象时,默认情况下 ...

  6. 浩哥解析MyBatis源码(三)——Transaction事务模块

    原创作品,可以转载,但是请标注出处地址:http://www.cnblogs.com/V1haoge/p/6634151.html 1.回顾 之前介绍了Environment环境类,这其实是一个单例类 ...

  7. MyBatis源码解析(三)——Transaction事务模块

    原创作品,可以转载,但是请标注出处地址:http://www.cnblogs.com/V1haoge/p/6634151.html 1.回顾 之前介绍了Environment环境类,这其实是一个单例类 ...

  8. Java JDBC高级特性

    1.JDBC批处理 实际开发中需要向数据库发送多条SQL语句,这时,如果逐条执行SQL语句,效率会很低,因此可以使用JDBC提供的批处理机制.Statement和PreparedStatemen都实现 ...

  9. Java JDBC连接SQL Server2005错误:通过端口 1433 连接到主机 localhost 的 TCP/IP 连接失败 及sql2008外围服务器

    转载:Java JDBC连接SQL Server2005错误:通过端口 1433 连接到主机 localhost 的 TCP/IP 连接失败 错误原因如下: Exception in thread & ...

  10. JDBC&&c3p0、事务、批处理、多线程 于一体的经典秘方QueryRunner

    目录: 基础篇_功能各自回顾 JDBC基础代码回顾(使用JdbcUtils工具简化) c3p0数据库连接池的使用(使用JdbcUtils工具简化) 大数据的插入(使用c3p0+JdbcUtils工具简 ...

随机推荐

  1. 没有 Git,如何下载 Gitee 代码?

    目录 没有 Git,如何下载 Gitee 代码? 注册 Gitee 账号 下载代码压缩包 没有 Git,如何下载 Gitee 代码? 鉴于看我博客的人很多都是大学本科生.非 CS 专业,大部分人都不会 ...

  2. java基础-匿名类/对象

    最近有同事问我,以下这个语句是什么意思? MqMessge<MqMessgeThink> mm= JSON.parseObject(message.toString(),new TypeR ...

  3. SDL3 入门(3):三角形

    SDL3 提供了 SDL_RenderGeometry 函数绘制几何图形,用法和 OpenGL 差不多,先定义顶点数据,然后根据顶点数据绘制几何图形. 绘制三角形的代码如下: std::array&l ...

  4. Ubuntu 18.04 安装OneDrive自动同步

    Ubuntu 18.04 安装OneDrive自动同步 Windows10系统已经自带了OneDrive的自动同步功能,对于多设备用户而言已经成为了一个非常方便传输保存文件的途径,在Ubuntu下也有 ...

  5. QT学习:01 工程文件详解

    --- title: framework-cpp-qt-01-工程文件详解 EntryName: framework-cpp-qt-01-project-file date: 2020-04-08 1 ...

  6. vba--将excel单元格格式改为常规格式

    Sub 改格式() ActiveWorkbook.activesheet.Select For Each Rng In ActiveSheet.UsedRange With Rng .NumberFo ...

  7. Salt安装部署

    Salt安装部署 一:salt简介 ​ 早期运维人员会根据自己的生产环境来写特定脚本完成大量重复性工作,这些脚本复杂且难以维护.系统管理员面临的问题主要是1.系统配置管理,2.远程执行命令,因此诞生了 ...

  8. Mysql与Redis如何保证数据的一致性?

    问题分析: 当MySQL中的数据发生更新时,就面临一个问题,如何确保MySQL与Redis数据的一致性,我们有两个选择: 先更新MySQL,后删除(或更新)Redis 先删除(或更新)Redis,后更 ...

  9. SpringBoot快速插入Mysql 1000万条数据

    导读 有时候为了验证系统瓶颈,需要往数据库表中插入大量数据,可以写sheel脚本插入,前几天为了插入100万条数据,走的sheel脚本(点我直达),插入速度简直无法直视,花了3小时,才插入了10万条, ...

  10. C#事件总结(二)

    续接上一篇文<C#事件总结>,那是通过一个结合例子的文字描述,接下来我将通过图文形式展现. 现在VS开发环境中看看事件是什么样子的: 再来看看我的笔记,希望对你的理解有帮助. 哦,顺便提醒 ...