您的位置:首页 > 博客中心 > 数据库 >

MySQL数据库学习笔记(十)----JDBC事务处理、封装JDBC工具类

时间:2022-03-14 01:38

 

首先需要回顾一下上一篇文章中的内容:

一、JDBC事务处理:

我们已经知道,事务的概念即:所有的操作要么同时成功,要么同时失败。在MySQL中提供了Commit、Rollback命令进行事务的提交与回滚。实际上在JDBC中也存在事务处理,如果要想进行事务处理的话,则必须按照以下的步骤完成。

JDBC中事务处理的步骤:

1、要取消掉JDBC的自动提交:void setAutoCommit(boolean autoCommit)

2、执行各个SQL语句,加入到批处理之中

3、如果所有语句执行成功,则提交事务 commit();如果出现了错误,则回滚:rollback()

核心代码:

conn.setAutoCommit(false); // 取消自动提交
把SQL语句加入批处理
stmt.addBatch(…) ()
stmt.addBatch(…)
//执行批处理操作
stmt.executeBatch();
conn.commit(); // 提交事务

//如果发生错误
conn.rollback();

代码举例:

首先在sql中创建一个空的数据库,现在在java中,使用PreparedStatement插入数据并修改数据。正常情况下,代码应该这样写:

 1 package com.vae.jdbc;
 2 
 3 import java.sql.Connection;
 4 import java.sql.DriverManager;
 5 import java.sql.PreparedStatement;
 6 import java.sql.ResultSet;
 7 import java.sql.SQLException;
 8 
 9 public class JDBCtest {
10 
11 
12     //数据库连接地址
13     public final static String URL = "jdbc:mysql://localhost:3306/JDBCdb";
14     //用户名
15     public final static String USERNAME = "root";
16     //密码
17     public final static String PASSWORD = "smyh";
18     //驱动类
19     public final static String DRIVER = "com.mysql.jdbc.Driver";
20     
21     
22     public static void main(String[] args) {
23         // TODO Auto-generated method stub
24         //insert(p);
25         //update(p);
26         //delete(3);
27         insertAndQuery();
28     }
29     
30     
31     //方法:使用PreparedStatement插入数据、更新数据
32     public static void insertAndQuery(){
33         Connection conn = null;
34         try {
35             Class.forName(DRIVER);
36             conn = DriverManager.getConnection(URL, USERNAME, PASSWORD);
37             String sql1 = "insert into user(name,pwd)values(?,?)";
38             String sql2 = "update user set pwd=? where name=?";
39             PreparedStatement ps = conn.prepareStatement(sql1);
40             ps.setString(1, "smyhvae");
41             ps.setString(2, "007");            
42             ps.executeUpdate();
43             
44             ps = conn.prepareStatement(sql2);
45             ps.setString(1, "008");
46             ps.setString(2, "smyh");            
47             ps.executeUpdate();            
48             
49             ps.close();
50             conn.close();            
51             
52         } catch (ClassNotFoundException e) {
53             e.printStackTrace();
54         } catch (SQLException e) {
55             e.printStackTrace();
56         }
57     }
58     
59 }

事务处理:

现在我们把上面的插入操作和修改操作变成一个事务,就要增加一部分代码了。修改上方的insertAndQuery()方法里面的代码:

 1 //方法:使用PreparedStatement插入数据、更新数据
 2     public static void insertAndQuery(){
 3         Connection conn = null;
 4         try {
 5             Class.forName(DRIVER);
 6             conn = DriverManager.getConnection(URL, USERNAME, PASSWORD);
 7             conn.setAutoCommit(false);//设置为手动提交事务
 8             String sql1 = "insert into user(name,pwd)values(?,?)";
 9             String sql2 = "update user set pwd=? where name=?";
10             PreparedStatement ps = conn.prepareStatement(sql1);
11             ps.setString(1, "smyhvae");
12             ps.setString(2, "007");            
13             ps.executeUpdate();
14             
15             ps = conn.prepareStatement(sql2);
16             ps.setString(1, "008");
17             ps.setString(2, "smyh");            
18             ps.executeUpdate();            
19             conn.commit(); //如果所有sql语句成功,则提交事务
20             ps.close();
21             conn.close();
22             
23         } catch (ClassNotFoundException e) {
24             e.printStackTrace();
25         } catch (SQLException e) {
26             e.printStackTrace();
27             try {
28                 conn.rollback();//只要有一个sql语句出现错误,则将事务回滚 
29             } catch (SQLException e1) {
30                 e1.printStackTrace();
31             }
32         }
33         
34     }

核心代码是第07行、19行、28行。这三行代码就完成了事务处理的操作。两个sql语句中,只要有一个语句出现错误,程序将无法运行,说明事务提交失败,且报错如下:

gxlsystem.com,布布扣

 

二、封装JDBC工具类

之前的JDBC代码分析:

我们可以先回顾一下上一篇博文中的第五段:使用PreparedStatement重构增删改查。

通过分析可以发现有以下不足:有许多重复的代码、每次都要加载驱动、获取连接等。增删改查无非只是slq语句不一样而已。

封装工具类就是一个抽象的过程,我们可以把现在代码中非常公用的代码抽取出来,形成一个工具类。

  • 第一步:抽象公共的代码到工具类。
  • 第二步:为提高可以连接不同数据库的能力,将连接数据库的URL、用户名,密码等信息编写在一个属性文件(jdbc.properties)中,方便以后进行修改。gxlsystem.com,布布扣
     1 package com.vae.jdbc;
     2 
     3 public class Person {
     4     private int id;
     5     private String name;
     6     private int age;
     7     private String description;
     8     public int getId() {
     9         return id;
    10     }
    11     public void setId(int id) {
    12         this.id = id;
    13     }
    14     public String getName() {
    15         return name;
    16     }
    17     public void setName(String name) {
    18         this.name = name;
    19     }
    20     public int getAge() {
    21         return age;
    22     }
    23     public void setAge(int age) {
    24         this.age = age;
    25     }
    26     public String getDescription() {
    27         return description;
    28     }
    29     public void setDescription(String description) {
    30         this.description = description;
    31     }
    32     public Person(int id, String name, int age, String description) {
    33         super();
    34         this.id = id;
    35         this.name = name;
    36         this.age = age;
    37         this.description = description;
    38     }
    39     public Person(String name, int age, String description) {
    40         super();
    41         this.name = name;
    42         this.age = age;
    43         this.description = description;
    44     }
    45     public Person() {
    46         super();
    47         // TODO Auto-generated constructor stub
    48     }
    49     @Override
    50     public String toString() {
    51         return "Person [id=" + id + ", name=" + name + ", age=" + age
    52                 + ", description=" + description + "]";
    53     }
    54     
    55     
    56 }
    Person.java

    (4)然后开始编写主程序来测试一下:

     1 package com.vae.jdbc;
     2 
     3 import java.sql.Connection;
     4 import java.sql.PreparedStatement;
     5 import java.sql.ResultSet;
     6 import java.sql.SQLException;
     7 
     8 
     9 public class Test {
    10     
    11     public static void main(String[] args) {
    12         Person p = new Person();
    13         p = findById(1);
    14         System.out.println(p);
    15     }
    16     
    17     
    18 
    19 
    20     /**
    21      * 查询的方法
    22      */
    23     public static Person findById(int id){
    24         Person p =null;
    25         //通过工具类获取数据库连接
    26         Connection conn = DBUtils.getConnection();
    27         PreparedStatement ps = null;
    28         ResultSet rs = null;
    29         String sql = "select name,age,description from person where id=?";
    30         try {
    31             ps = conn.prepareStatement(sql);
    32             //设置占位符对应的值
    33             ps.setInt(1, id);
    34             rs = ps.executeQuery();
    35             if(rs.next()){
    36                 p = new Person();
    37                 p.setName(rs.getString(1));
    38                 p.setAge(rs.getInt(2));
    39                 p.setDescription(rs.getString(3));
    40             }
    41         } catch (SQLException e) {
    42             e.printStackTrace();
    43         }finally{
    44             //通过工具类关闭数据库连接
    45             DBUtils.close(rs, ps, conn);
    46         }
    47         return p;
    48         
    49     }
    50 
    51 }

    测试程序是可以运行的。这样,我们的工具类就建好了。

热门排行

今日推荐

热门手游