gpt4 book ai didi

Java与Oracle实现事务(JDBC事务)实例详解

转载 作者:qq735679552 更新时间:2022-09-27 22:32:09 24 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章Java与Oracle实现事务(JDBC事务)实例详解由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

Java与Oracle实现事务(JDBC事务)实例详解 。

J2EE支持JDBC事务、JTA事务和容器事务事务,这里说一下怎样实现JDBC事务.

       JDBC事务是由Connection对象所控制的,它提供了两种事务模式:自己主动提交和手动提交,默认是自己主动提交.

       自己主动提交就是:在JDBC中。在一个连接对象Connection中。默认把每一个SQL语句的运行都当做是一个事务(即每次运行完SQL语句都会马上将操作更新到数据库).

       手动提交就是:当须要一次性运行多个SQL语句,将多个SQL语句组成一个事务(即要么都成功,要么回滚全部的操作)时,就得手动提交.

        看一个样例:        。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
import java.sql.*;
 
public class TransactionTest{
 
public static void main(String[] args) throws SQLException {
  try {
      Class.forName( "oracle.jdbc.driver.OracleDriver" );
         Connection conn = DriverManager.getConnection( "jdbc:oracle:thin:@127.0.0.1:1521:orcl" , "TransactionTest" , "123456" );
  
         //将事务模式设置为手动提交事务:
         conn.setAutoCommit( false );
  
         //设置事务的隔离级别。
         conn.setTransactionIsolation(Connection.TRANSACTION_REPEATABLE_READ);
        
  //运行插入操作
         String sqlInsert = "insert into t_user(userName,userPassword) values(?,?
)";       
         pstmt = conn.prepareStatement(sqlInsert);
         pstmt.setString( 1 , "danny" );
         pstmt.setString( 2 , "123" );
         pstmt.executeUpdate();
  
  //运行改动操作
         String sqlUpdate = "update t_user set userPassword=? where userName = ?" ;
         pstmt = conn.prepareStatement(sqlUpdate);
         pstmt.setString( 1 , "123456" );
         pstmt.setString( 2 , "danny" );       
         pstmt.executeUpdate();
  
         //提交事务
         conn.commit();
  
       } catch (Exception e) {       
         // 若事务发生异常,回滚事务
         conn.rollback();
       } finally {       
         if (pstmt!= null ) {
           pstmt.close();
         }
         if (conn!= null ) {
           conn.close();
         }
       }
}
}

       当须要插入和更新这两个操作同一时候运行时,要么两个操作都成功,假设有一个失败。则撤销全部的操作.

       宏观来看须要例如以下四个步骤:     。

       1、将事务模式设置为手动提交事务:

             conn.setAutoCommit(false); 。

       2、设置事务的隔离级别:

             conn.setTransactionIsolation(Connection.TRANSACTION_READ_COMMITTED),

       3、提交事务:

             conn.commit(),

       4、假设发生异常,回滚事务:

             conn.rollback(),

       从上面看,JDBC事务使用较为方便,但因为它是由Connection对象所控制的,所以它的缺点是事务的范围仅仅局限于一个数据库的连接,同一个事务中无法操作多个数据库.

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持! 。

原文链接:http://www.cnblogs.com/claireyuancy/p/6699923.html 。

最后此篇关于Java与Oracle实现事务(JDBC事务)实例详解的文章就讲到这里了,如果你想了解更多关于Java与Oracle实现事务(JDBC事务)实例详解的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com