一、事务(Transaction)

  1、 在开发中我们的一个业务往往需要同时操作多个表,这些操作往往是不可分割,业务中的对数据库的多次操作,要么同时成功,要么全都失败。

  2、注意:我们在同一个事务中使用的数据库连接(Connection)必须是同一个

  3、事务的特性(ACID):

    1.原子性(atomicity)

        一个事务是一个不可分割的工作单位,事务中包括的诸操作要么都做,要么都不做。

    2.一致性(consistency)

        事务必须是使数据库从一个一致性状态变到另一个一致性状态。一致性与原子性是密切相关的。

    3.隔离性(isolation)

           一个事务的执行不能被其他事务干扰。

        即一个事务内部的操作及使用的数据对并发的其他事务是隔离的,并发执行的各个事务之间不能互相干扰。

    4.持久性(durability)

        持久性也称永久性(permanence),指一个事务一旦提交,它对数据库中数据的改变就应该是永久性的。

        接下来的其他操作或故障不应该对其有任何影响。

  4、操作失误的基本步骤:

      1.开启事务

        - 开启事务以后,我们只后的所有操作将都会在同一个事务当中

      2.操作数据库

        - 开启事务以后再去操作数据库,所有操作将不会直接提交到数据库中

      3.提交事务

        - 将修改应用到数据库

      4.回滚事务

        - 数据库操作过程中出现异常了,回滚事务,回滚事务以后,数据库变成开启事务之前的状态

  5、 mysql中的事务控制

    #开启事务

      START TRANSACTION

    #回滚事务

      ROLLBACK

    #提交事务

      COMMIT

  6、 JDBC中的事务主要通过Connection对象来控制的

    1.开启事务

      void setAutoCommit(boolean autoCommit) throws SQLException;

        - 设置事务是否自动提交,默认是自动提交

        - 设置事务手动提交

          conn.setAutoCommit(false);

    2.提交事务

      void commit() throws SQLException;

        - 提交事务

          conn.commit()

    3.回滚事务

      void rollback() throws SQLException;

        - 回滚事务

          conn.rollback()

二、事务控制

  数据访问层的方法用来执行对数据库的操作,为了保证同一个事务中各个原子操作使用的数据库连接(Connection)是同一个,

    我们一般在Service层获取数据库连接并传递到dao层

   public void updateBalance(Connection conn,double money,Integer id) throws SQLException{
PreparedStatement ps=null;
String sql="update t_money set balance=balance+? where id=?"; try {
ps=conn.prepareStatement(sql);
ps.setDouble(1, money);
ps.setInt(2, id);
ps.executeUpdate();
} finally {
//在数据访问层,不能关闭数据库连接,必须保持事务的各个原子操作是同一连接
JDBCUtils.closeStatement(null, ps);
}
}

  测试代码:

   @Test
public void testTransaction() {
Connection conn=null;
Dao dao=new Dao();
try {
conn=JDBCUtils.getConnection(); //获取数据库连接
conn.setAutoCommit(false); //组织事务自动提交
dao.updateBalance(conn, -100, 1); //原子操作1
dao.updateBalance(conn, +100, 2); //原子操作2
conn.commit(); //提交事务
} catch (Exception e) {
e.printStackTrace();
try {
conn.rollback(); //事务未完整执行成功,回滚
} catch (SQLException e1) {
e1.printStackTrace();
}
}
}

Java——事务的更多相关文章

  1. 转!!java事务的处理

    java的事务处理,如果对数据库进行多次操作,每一次的执行或步骤都是一个事务.如果数据库操作在某一步没有执行或出现异常而导致事务失败,这样有的事务被执行有的就没有被执行,从而就有了事务的回滚,取消先前 ...

  2. 深入Java事务的原理与应用

    一.什么是JAVA事务    通常的观念认为,事务仅与数据库相关. 事务必须服从ISO/IEC所制定的ACID原则.ACID是原子性(atomicity).一致性(consistency).隔离性 ( ...

  3. java事务的类型——面试被问到

    Java事务的类型有三种:JDBC事务.JTA(Java Transaction API)事务.容器事务. 1.JDBC事务 JDBC 事务是用 Connection 对象控制的.JDBC Conne ...

  4. java事务管理

    一.什么是Java事务 通常的观念认为,事务仅与数据库相关. 事务必须服从ISO/IEC所制定的ACID原则.ACID是原子性(atomicity).一致性(consistency).隔离性(isol ...

  5. java事务的处理

    java的事务处理,如果对数据库进行多次操作,每一次的执行或步骤都是一个事务. 如果数据库操作在某一步没有执行或出现异常而导致事务失败,这样有的事务被执行有的就没有被执行,从而就有了事务的回滚,取消先 ...

  6. 分布式事务(二)Java事务API(JTA)规范

    一.引子 既然出现了分布式场景(DTP模型), 大java也及时制定出一套规范来给各大应用服务器.数据库/mq等厂商使用,以方便管理互通--->JTA闪亮登场.JTA(Java Transact ...

  7. java事务 深入Java事务的原理与应用

    一.什么是JAVA事务 通常的观念认为,事务仅与数据库相关. 事务必须服从ISO/IEC所制定的ACID原则.ACID是原子性(atomicity).一致性(consistency).隔离性 (iso ...

  8. java 事务

    之前的事务介绍基本都是数据库层面的事务,本文来介绍一下J2EE中和事务相关的内容,在阅读本文之前,希望读者对分布式有一定的了解. 关于事务的基础知识这里不再详细介绍,想要了解的同学可以在我的博客中阅读 ...

  9. Java事务管理之Spring+Hibernate

    环境与版本 除了上一篇中的hibernate的相关lib 外 Java事务管理之Hibernate 还需要加入Spring的lib 包和如下的一些依赖包 org.aopallianceorg.aspe ...

  10. java事务(三)

    java事务(三)——自己实现分布式事务 在上一篇<java事务(二)——本地事务>中已经提到了事务的类型,并对本地事务做了说明.而分布式事务是跨越多个数据源来对数据来进行访问和更新,在J ...

随机推荐

  1. Oracle data guard学习

    Oracle data guard学习:三思笔记 Data guard 1data guard结构: data guard是一个集合,由一个primary数据库(生产数据库)和一个或多个standby ...

  2. mybatis 学习四 (上)resutlMap

    SQL 映射XML 文件是所有sql语句放置的地方.需要定义一个workspace,一般定义为对应的接口类的路径.写好SQL语句映射文件后,需要在MyBAtis配置文件mappers标签中引用,例如: ...

  3. MFRC522模块开发笔记

    Write_to_Card(-)和Read_from_Card(-)可谓是所有函数的终点,而SPIWriteByte(-)则是最底层对MFRC522模块进行操作的函数,所有函数都是为了Write_to ...

  4. SqlServer——事务一进阶之锁的概念(SqlServer技术内幕 T-SQL程序设计 第九章)

         一.事务的概念及ACID特性 对于单独一条SQL语句,数据库会隐式的将其作为事务,即该SQL语句要么执行成功,要么失败(相当于不执行),而我们通常说的事务就是将多条SQL语句放在 begin ...

  5. oracle时间段查询-从00:00:00开始

    之所以记录一下这篇博文,是因为前段时间搞的一个查询发现要从00:00:00这个时间段开始,必须要通过拼接字符串. <select id="queryApplyProgressList& ...

  6. js调试的一点小知识

    1.如果想要js代码被XHTML和HTML解析,就可以使用如下方式 <script type="text/javascript"> //<![CDATA[ fun ...

  7. request 10.0 模块安装

     https://pypi.python.org/packages/49/6f/183063f01aae1e025cf0130772b55848750a2f3a89bfa11b385b35d7329d ...

  8. GUI编程01

    1 tkinter TkInter是标准的Python GUI库.的Python与Tkinter的结合提供了一个快速和容易的方法来创建GUI应用程序. Tkinter的提供了一个强大的面向对象的接口T ...

  9. 利用General框架开发RDLC报表

    RDLC是微软推出的自家的报表软件,虽然没有一些第三方的报表软件强大好用,但是作为VisualStudio集成的报表工具,在客户要求不高的情况下还是非常值得一用的,本文将介绍通过General代码生成 ...

  10. C语言-郝斌笔记-005菲波拉契序列

    菲波拉契序列 /* 菲波拉契序列 1 2 3 5 8 13 21 34 */ # include <stdio.h> int main(void) { int n; int f1, f2, ...