事务简介

数据库事务(Database Transaction) ,是指作为单个逻辑工作单元执行的一系列操作,要么完全地执行,要么完全地不执行。
事务是必须满足4个条件(ACID)
  • 事务的原子性( Atomicity):一组事务,要么全部成功;要么全部失败。
  • 一致性 (Consistency):事务在完成时,必须使所有的数据都保持一致状态。在相关数据库中,所有规则都必须应用于事务的修改,以保持所有数据的完整性。比如一个学生表中新插入了一条记录,这个学生的class_id必须是一个已经存在的正确的,A账户向B账户转账,不能出现负数,如果不做任何保障,出现了负数,这就是破坏了一致性可以认为是一致性表示数据本来是正确的,经过了事务,转换为了另外的一个状态,仍旧是正确的。
  • 隔离性(Isolation):由并发事务所作的修改必须与任何其它并发事务所作的修改隔离。也就是说另一并发事务要么读取的是事务前的状态,要么是事务后的状态,不会是这个事务的中间状态。
  • 持久性(Durability):事务完成之后,它对于系统的影响是永久性的。该修改即使出现致命的系统故障也将一直保持。
 
在默认情况下,MySQL每执行一条SQL语句,都是一个单独的事务
如果需要将多条SQL语句设在在同一个事务中,那么需要开启事务和结束事务
JDBC中与事务有关的方法
Connection与事务有关的主要方法:
  • setAutoCommit(boolean):设置是否为自动提交事务,如果true(默认值为true)表示自动提交,也就是每条执行的SQL语句都是一个单独的事务;如果设置为false,那么相当于开启了事务,con.setAutoCommit(false) 表示开启事务。
  • commit():提交结束事务。
  • rollback():回滚结束事务。
  • setSavepoint():设置保存点。

事务使用示例

package jdbc;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
public class MyTransactional {
public static void main(String[] args) throws Exception{
String user = "root";
String password = "123456";
String url = "jdbc:mysql://localhost:3306/sampledb?useUnicode=true&characterEncoding=utf-8";
//2、获取连接对象
Connection conn = DriverManager.getConnection(url, user, password);
String sql = "delete from student where id='59'";
//2、获得sql语句执行对象
Statement stmt = conn.createStatement();
conn.setAutoCommit(false);
//3、执行并保存结果集
int rows = stmt.executeUpdate(sql);
System.out.println("受影响的行: "+rows);
conn.commit();
// conn.rollback();
conn.close();
stmt.close();
}
}
在执行前开启事务,conn.setAutoCommit(false);
注意:一定是执行前
只有开启事务和结束事务之间的执行才属于这个事务,如果像下面这样,可以认为是两个事务,前面一个自动提交了,然后开启了新的事务,然后回滚了新的事务
    stmt.executeUpdate(sql);
conn.setAutoCommit(false);
conn.rollback();
最终通过commit或者rollback 结束事务。
通常的一个使用形式为:
try {
con = DBConnection.getConnection();
//开启事务
con.setAutoCommit(false); //处理业务逻辑 //提交事务
con.commit();
}
catch (SQLException e) {
e.printStackTrace();
//出现异常,回滚事务
try {
con.rollback();
System.out.println("JDBC Transaction rolled back successfully");
}
catch (SQLException e1) {
System.out.println("SQLException in rollback" + e.getMessage());
}
}

保存点

有的时候可能并不需要将一整个事务进行回滚,一个复杂的事务可能由几个一致性的阶段组成
保存点就是在一个事务中,插入几个还原点,再出现问题时,可以及时的撤回到这个地方来
当撤回到一个还原点时,事务还在,仍在进行中,所以还需要再次的COMMIT,这次的COMMIT,保存点以下的执行相当于不存在。
package jdbc;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Savepoint;
import java.sql.Statement;
public class MyTransactional {
public static void main(String[] args) throws Exception{
String user = "root";
String password = "123456";
String url = "jdbc:mysql://localhost:3306/sampledb?useUnicode=true&characterEncoding=utf-8";
//2、获取连接对象
Connection conn = DriverManager.getConnection(url, user, password);
conn.setAutoCommit(false);
String sql1 = "delete from student where id='158'";
String sql2 = "delete from student where id='159'";
//2、获得sql语句执行对象
Statement stmt = conn.createStatement();
//3、执行并保存结果集
stmt.executeUpdate(sql1);
Savepoint savepoint1 = conn.setSavepoint("savepoint1");
stmt.executeUpdate(sql2);
Savepoint savepoint2 = conn.setSavepoint("savepoint2");
conn.rollback(savepoint1);
conn.commit();
// conn.rollback();
conn.close();
stmt.close();
}
}
上面的示例中,执行了两次删除,删除id=158时,创建保存点savepoint1;删除id=159时,创建保存点savepoint2
将事务回滚到保存点1 conn.rollback(savepoint1);,然后进行提及,保存点savepoint1以上的部分成功提交,后面的部分没有提交
也就是回滚到哪个保存点,那个保存点以下就相当于不存在
保存点就是这样将一整个完整的过程进行了拆分,rollback到哪个保存点,哪个保存点以下就会回滚,之前的就会提交
一定要注意: conn.rollback(savepoint1); 并不会结束事务,只有 conn.commit();或者 conn.rollback();方法才会结束事务。

JDBC事务与保存点 JDBC简介(七)的更多相关文章

  1. day18(JDBC事务&连接池介绍&DBUtils工具介绍&BaseServlet作用)

    day18总结 今日思维导图: 今日内容 事务 连接池 ThreadLocal BaseServlet自定义Servlet父类(只要求会用,不要求会写) DBUtils à commons-dbuti ...

  2. Spring 中的 JDBC 事务

    Spring 对 JDBC 的支持 JdbcTemplate 简介 •为了使 JDBC 更加易于使用, Spring 在 JDBC API 上定义了一个抽象层, 以此建立一个 JDBC 存取框架. • ...

  3. JDBC 事务控制

    一.简介: 前面一遍提到了jdbc事务相关的概念.从中了解到事务应具有ACID特性.所以对于javaweb开发来说,某一个service层的方法,应该是一个事务,应该是具有原子性的.特别是当一个ser ...

  4. Java的JDBC事务详解(转)

    事务的特性: 1) 原子性(atomicity):事务是数据库的逻辑工作单位,而且是必须是原子工作单位,对于其数据修改,要么全部执行,要么全部不执行. 2) 一致性(consistency):事务在完 ...

  5. JDBC事务和JTA事务的区别

    转自:JDBC和JTA事务的区别 一.事务概述事务表示一个由一系列的数据库操作组成的不可分割的逻辑单位,其中的操作要么全做要么全都不做.与事务相关的操作主要有:BEGIN TRANSACTION: 开 ...

  6. Java的JDBC事务详解

    Java的JDBC事务详解         分类:             Hibernate              2010-06-02 10:04     12298人阅读     评论(9) ...

  7. 数据库事务的四大特性以及4种事务的隔离级别-以及对应的5种JDBC事务隔离级别

    本篇讲诉数据库中事务的四大特性(ACID),并且将会详细地说明事务的隔离级别. 如果一个数据库声称支持事务的操作,那么该数据库必须要具备以下四个特性: ⑴ 原子性(Atomicity) 原子性是指事务 ...

  8. JDBC事务和JTA (XA)事务区别

    JDBC 事务 JDBC 事务是用 Connection 对象控制的.JDBC Connection 接口( java.sql.Connection )提供了两种事务模式:自动提交和手工提交. 在jd ...

  9. JDBC事务和数据库事务嵌套的讨论 .

    首先必须执行con.setAutoCommit(false)方法,将JDBC事务设置为手动提交,否则手动提交con.commit()无效,手动回滚con.rollback()引发SQLExceptio ...

随机推荐

  1. json字符串的拼接

    关于json字符串的解析与拼接,第一次接触,留下个笔记了.......解析,是改的代码,拼接是纯的,解析就不说了,笔记一下拼接了 关于解析主要分三部分,一个是第一层处理,一个是第二层处理,一个是进行& ...

  2. history.back(-1) 和history.go(-1) 有什么区别?

    history.back(-1) 返回上一页,当前页面的数据都没有保存下来.就像当前也没有出现过一样. history.go(-1)    返回上一页,当前页的内容都保存下来了,包括session,等 ...

  3. Chrome 启动全屏,并可以F11退出

    新建start.bat文件,作用,打开浏览器,并模拟按下F11,全屏,内容如下: start C:\Program" "Files" "(x86)\Google ...

  4. Spring + SpringMVC + Mybatis项目中redis的配置及使用

    maven文件 <!-- redis --> <dependency> <groupId>redis.clients</groupId> <art ...

  5. 严重: A child container failed during start

    四月 20, 2019 4:54:28 下午 org.apache.coyote.AbstractProtocol init 信息: Initializing ProtocolHandler [&qu ...

  6. OJ002

    register:这个关键字请求编译器尽可能的将变量存在CPU内部寄存器中,而不是通过内存寻址访问,以提高效率.注意是尽可能,不是绝对. 因为,如果定义了很多register变量,可能会超过CPU的寄 ...

  7. 大数据BI框架知识点备注

    将这段时间的一些基于大数据方案的BI知识点暂时做些规整,可能还存在较多问题,后续逐步完善修改. 数据模型: 1.星型模型和雪花模型,同样是将业务表拆分成事实表和纬度表:例如一个员工数据表,可以拆分为员 ...

  8. [Swift]LeetCode924.尽量减少恶意软件的传播 | Minimize Malware Spread

    In a network of nodes, each node i is directly connected to another node j if and only if graph[i][j ...

  9. Python面试真题第三节

    51.正则匹配,匹配日期2018-03-20 url='https://sycm.taobao.com/bda/tradinganaly/overview/get_summary.json?dateR ...

  10. Windows系统下安装Redis

    1.首先你要有redis-latest-windws和redisclient-客户端工具 2.在redis-latest-windws文件夹内创建一个批处理文件  start.bat 创建批处理文件的 ...