Java事务处理类(源码)

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介:

Mysql5很好的支持了事物处理功能。不过支持这个功能的只有两种表类型。

 

分别是BDB,InnoDB。

 

先建立一个表,名为Kiss,数据为id (int),name(varchar),pop(varchar)。

 

下面是源码:

 

复制代码
import  java.sql. * ;

ExpandedBlockStart.gif
public   class  TestCommit {
ExpandedSubBlockStart.gif    
public static void main(String args[]){
    Connection conn
=null;
ExpandedSubBlockStart.gif    
try{
       Class.forName(
"com.mysql.jdbc.Driver");
       String url
="jdbc:mysql://localhost:3306/kiss";
       conn
=DriverManager.getConnection(url,"username","password");
       
boolean autoCommit=conn.getAutoCommit();
       
//关闭自动提交功能
       conn.setAutoCommit(false);
       Statement stmt
=conn.createStatement();
       stmt.executeUpdate(
"insert into sun values(15,'Hello','Beijing')");
       stmt.executeUpdate(
"insert into sun values(16,'Hi','shanghai')");
       ResultSet rs
=stmt.executeQuery("select * from sun");
ExpandedSubBlockStart.gif       
while(rs.next()){
            System.out.print(
"DeptNo:"+rs.getInt(1));
            System.out.print(
"\tDeptName:"+rs.getString(2));
            System.out.println(
"\tLOC:"+rs.getString(3));
}
   
//提交事务
    conn.commit();
//恢复原来的提交模式
    conn.setAutoCommit(autoCommit);
    stmt.close();
ExpandedSubBlockStart.gif}
catch(Exception e){
    System.out.println(
"操作失败!!!任务撤销!!!");
ExpandedSubBlockStart.gif    
try{
        
//回滚、取消前述操作
        conn.rollback();
ExpandedSubBlockStart.gif    }
catch(Exception e1){
      e1.printStackTrace();
    }

ExpandedSubBlockStart.gif}
finally{
ExpandedSubBlockStart.gif   
try{
ExpandedSubBlockStart.gif         
if(conn!=null){
            conn.close();
         }

ExpandedSubBlockStart.gif   }
catch(Exception e1){
     e1.printStackTrace();
    }

   }

    }

}
复制代码

 

 

执行第一次执行这个类,id如果不冲突,就可以顺利插入数据,第二次插入,id冲突,则实现回滚。

 

下面是部分回滚:

 

 

 

复制代码
import  java.sql. * ;

ExpandedBlockStart.gif
public   class  TestSavepoint {
ExpandedSubBlockStart.gif    
public static void main(String args[]){
    Connection conn
=null;
ExpandedSubBlockStart.gif    
try{
       Class.forName(
"com.mysql.jdbc.Driver");
       String url
="jdbc:mysql://localhost:3306/kiss";
       conn
=DriverManager.getConnection(url,"username","password");
       
boolean autoCommit=conn.getAutoCommit();
       
//关闭自动提交功能
       conn.setAutoCommit(false);
       Statement stmt
=conn.createStatement();
       stmt.executeUpdate(
"insert into sun values(21,'Hello','Beijing')");
       stmt.executeUpdate(
"insert into sun values(22,'Hi','shanghai')");
       Savepoint sp1
=conn.setSavepoint("p1");
       stmt.executeUpdate(
"insert into sun values(25,'shiyang','xingtai')");
       Savepoint sp2
=conn.setSavepoint("p2");
       stmt.executeUpdate(
"insert into sun values(60,'shiyang','baoding')");
       ResultSet rs
=stmt.executeQuery("select avg(id) from sun");
       rs.next();
       
double avg_id=rs.getDouble(1);
ExpandedSubBlockStart.gif       
if(avg_id>100){
         conn.rollback(sp1);
ExpandedSubBlockStart.gif       }
else if(avg_id>30){
         conn.rollback(sp2);
       }

       conn.commit();
       rs
=stmt.executeQuery("select * from sun");
ExpandedSubBlockStart.gif       
while(rs.next()){
            System.out.print(rs.getInt(
1));
            System.out.print(
"\t"+rs.getString(2).trim());
            System.out.println(
"\t"+rs.getString(3));
}
   
rs.close();
stmt.close();
ExpandedSubBlockStart.gif    }
catch(Exception e){
      System.out.println(
"Failure.rollback!!!");
ExpandedSubBlockStart.gif   
try{
       conn.rollback();
ExpandedSubBlockStart.gif   }
catch(Exception e1){
     e1.printStackTrace();
    }

    e.printStackTrace();
ExpandedSubBlockStart.gif   }
finally{
ExpandedSubBlockStart.gif     
try{
ExpandedSubBlockStart.gif       
if(conn!=null){
         conn.close();
       }

ExpandedSubBlockStart.gif     }
catch(Exception e1){
       e1.printStackTrace();
     }

   }

    }

}
复制代码

 

代码测试通过,完美运行。


本文转自施杨博客园博客,原文链接:http://www.cnblogs.com/shiyangxt/archive/2008/08/16/1269065.html,如需转载请自行联系原作者

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
3天前
|
运维 Java
Java版HIS系统 云HIS系统 云HIS源码 结构简洁、代码规范易阅读
云HIS系统分为两个大的系统,一个是基层卫生健康云综合管理系统,另一个是基层卫生健康云业务系统。基层卫生健康云综合管理系统由运营商、开发商和监管机构使用,用来进行运营管理、运维管理和综合监管。基层卫生健康云业务系统由基层医院使用,用来支撑医院各类业务运转。
21 5
|
2天前
|
Java 关系型数据库 MySQL
Elasticsearch【问题记录 01】启动服务&停止服务的2类方法【及 java.nio.file.AccessDeniedException: xx/pid 问题解决】(含shell脚本文件)
【4月更文挑战第12天】Elasticsearch【问题记录 01】启动服务&停止服务的2类方法【及 java.nio.file.AccessDeniedException: xx/pid 问题解决】(含shell脚本文件)
23 3
|
4天前
|
JavaScript Java 测试技术
基于Java的电影评论系统的设计与实现(源码+lw+部署文档+讲解等)
基于Java的电影评论系统的设计与实现(源码+lw+部署文档+讲解等)
19 0
|
4天前
|
JavaScript Java 测试技术
基于Java的在线日语培训平台的设计与实现(源码+lw+部署文档+讲解等)
基于Java的在线日语培训平台的设计与实现(源码+lw+部署文档+讲解等)
21 0
|
4天前
|
JavaScript Java 测试技术
基于Java的同城蔬菜配送管理系统的设计与实现(源码+lw+部署文档+讲解等)
基于Java的同城蔬菜配送管理系统的设计与实现(源码+lw+部署文档+讲解等)
10 0
|
4天前
|
JavaScript Java 测试技术
基于Java的心理预约咨询管理系统的设计与实现(源码+lw+部署文档+讲解等)
基于Java的心理预约咨询管理系统的设计与实现(源码+lw+部署文档+讲解等)
20 0
基于Java的心理预约咨询管理系统的设计与实现(源码+lw+部署文档+讲解等)
|
4天前
|
JavaScript Java 测试技术
基于Java的税务门户网站的设计与实现(源码+lw+部署文档+讲解等)
基于Java的税务门户网站的设计与实现(源码+lw+部署文档+讲解等)
3 0
|
4天前
|
JavaScript Java 测试技术
基于Java的高校毕业生就业管理系统的设计与实现(源码+lw+部署文档+讲解等)
基于Java的高校毕业生就业管理系统的设计与实现(源码+lw+部署文档+讲解等)
17 0
基于Java的高校毕业生就业管理系统的设计与实现(源码+lw+部署文档+讲解等)
|
4天前
|
JavaScript Java 测试技术
基于Java的家纺用品销售管理系统的设计与实现(源码+lw+部署文档+讲解等)
基于Java的家纺用品销售管理系统的设计与实现(源码+lw+部署文档+讲解等)
15 0
|
4天前
|
JavaScript Java 测试技术
基于Java的教务管理系统的设计与实现(源码+lw+部署文档+讲解等)
基于Java的教务管理系统的设计与实现(源码+lw+部署文档+讲解等)
19 0