封装JDBC操作数据库的方法

Posted 格物致知

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了封装JDBC操作数据库的方法相关的知识,希望对你有一定的参考价值。

自己动手封装java操作数据库的方法:

一:目录结构

 

二:所需依赖的第三方jar包

这里只需引入mysql-connector-java-5.1.8-bin.jar,mysql数据库驱动jar包

 

三:代码

1:和数据库进行交互,首先是数据源,获取连接,代码如下:

 1 /**
 2  * 
 3  */
 4 package com.hlcui.datasource;
 5 
 6 import java.sql.Connection;
 7 import java.sql.DriverManager;
 8 import java.sql.SQLException;
 9 
10 /**
11  * @author Administrator 定义获取和关闭数据源的方法
12  */
13 public class DataSourceUtil {
14 
15     /**
16      * 注册数据库驱动
17      */
18     static {
19         try {
20             Class.forName("com.mysql.jdbc.Driver");
21         } catch (ClassNotFoundException e) {
22             e.printStackTrace();
23         }
24     }
25 
26     /**
27      * 获取数据源
28      * 
29      * @throws SQLException
30      */
31     public static Connection getConnection(String url, String user,
32             String password) throws SQLException {
33         return DriverManager.getConnection(url, user, password);
34     }
35 
36     /**
37      * 关闭数据源
38      * 
39      * @throws SQLException
40      */
41     public static void closeConnection(Connection conn) throws SQLException {
42         if (null != conn) {
43             conn.close();
44         }
45     }
46 }

 

2:有个数据库连接之后,可以对数据库进行操作了

  1 /**
  2  * 
  3  */
  4 package com.hlcui.dao;
  5 
  6 import java.sql.Connection;
  7 import java.sql.PreparedStatement;
  8 import java.sql.ResultSet;
  9 import java.sql.SQLException;
 10 import java.util.ArrayList;
 11 import java.util.List;
 12 
 13 import com.hlcui.Constants;
 14 import com.hlcui.datasource.DataSourceUtil;
 15 import com.hlcui.entity.Student;
 16 
 17 /**
 18  * @author Administrator
 19  * 
 20  */
 21 public class DBUtil {
 22 
 23     /**
 24      * 查询所有学生信息
 25      * 
 26      * @return
 27      */
 28     public static List<Student> getAllStuInfo() {
 29         Connection conn = null;
 30         PreparedStatement ps = null;
 31         ResultSet rs = null;
 32         List<Student> stus = new ArrayList<Student>();
 33         try {
 34             conn = DataSourceUtil.getConnection(Constants.URL,
 35                     Constants.USERNAME, Constants.PASSWORD);
 36             String sql = "select * from student";
 37             ps = conn.prepareStatement(sql);
 38             rs = ps.executeQuery();
 39             while (rs.next()) {
 40                 int id = rs.getInt("id");
 41                 String name = rs.getString("name");
 42                 int age = rs.getInt("age");
 43                 double score = rs.getDouble("score");
 44                 Student s = new Student(id, name, age, score);
 45                 stus.add(s);
 46             }
 47 
 48         } catch (Exception e) {
 49             e.printStackTrace();
 50         } finally {
 51 
 52             try {
 53                 if (null != rs) {
 54                     rs.close();
 55                 }
 56                 if (null != ps) {
 57                     ps.close();
 58                 }
 59                 if (null != conn) {
 60                     DataSourceUtil.closeConnection(conn);
 61                 }
 62             } catch (SQLException e) {
 63                 e.printStackTrace();
 64             }
 65 
 66         }
 67         return stus;
 68     }
 69 
 70     /**
 71      * 根据id查询学生的信息
 72      */
 73     public static Student getStuInfoById(int id) {
 74         Connection conn = null;
 75         PreparedStatement ps = null;
 76         ResultSet rs = null;
 77         Student s = null;
 78         try {
 79             conn = DataSourceUtil.getConnection(Constants.URL,
 80                     Constants.USERNAME, Constants.PASSWORD);
 81             String sql = "SELECT * FROM student where id = ?";
 82             ps = conn.prepareStatement(sql);
 83             ps.setInt(1, id);
 84             rs = ps.executeQuery();
 85             while (rs.next()) {
 86                 String name = rs.getString("name");
 87                 int age = rs.getInt("age");
 88                 double score = rs.getDouble("score");
 89                 s = new Student(id, name, age, score);
 90             }
 91         } catch (Exception e) {
 92             e.printStackTrace();
 93         } finally {
 94             try {
 95                 if (null != rs) {
 96                     rs.close();
 97                 }
 98                 if (null != ps) {
 99                     ps.close();
100                 }
101                 if (null != conn) {
102                     DataSourceUtil.closeConnection(conn);
103                 }
104             } catch (Exception e2) {
105             }
106         }
107         return s;
108     }
109 
110     /**
111      * 增加学生信息
112      */
113     public static void saveStuInfo(Student stu) {
114         Connection conn = null;
115         PreparedStatement ps = null;
116         try {
117             conn = DataSourceUtil.getConnection(Constants.URL,
118                     Constants.USERNAME, Constants.PASSWORD);
119             String sql = "insert into student (id,name,age,score) values (?,?,?,?)";
120             ps = conn.prepareStatement(sql);
121             ps.setInt(1, stu.getId());
122             ps.setString(2, stu.getName());
123             ps.setInt(3, stu.getAge());
124             ps.setDouble(4, stu.getScore());
125             int insertCount = ps.executeUpdate();
126             System.out.println(isSuccess(insertCount));
127         } catch (Exception e) {
128             e.printStackTrace();
129         } finally {
130             try {
131                 if (null != ps) {
132                     ps.close();
133                 }
134                 if (null != conn) {
135                     conn.close();
136                 }
137             } catch (Exception e2) {
138                 e2.printStackTrace();
139             }
140         }
141     }
142 
143     /**
144      * 根据id删除学生信息
145      */
146     public static void deleteStuInfo(int id) {
147         Connection conn = null;
148         PreparedStatement ps = null;
149         try {
150             conn = DataSourceUtil.getConnection(Constants.URL,
151                     Constants.USERNAME, Constants.PASSWORD);
152             String sql = "delete from student where id = ?";
153             ps = conn.prepareStatement(sql);
154             ps.setInt(1, id);
155             int deleteCount = ps.executeUpdate();
156             System.out.println(isSuccess(deleteCount));
157         } catch (Exception e) {
158             e.printStackTrace();
159         } finally {
160             try {
161                 if (null != ps) {
162                     ps.close();
163                 }
164                 if (null != conn) {
165                     conn.close();
166                 }
167             } catch (Exception e2) {
168                 e2.printStackTrace();
169             }
170         }
171     }
172 
173     /**
174      * 根据id修改学生信息
175      */
176     public static void modifyStuInfo(Student stu) {
177         Connection conn = null;
178         PreparedStatement ps = null;
179         try {
180             conn = DataSourceUtil.getConnection(Constants.URL,
181                     Constants.USERNAME, Constants.PASSWORD);
182             String sql = "update student set name = ?,age = ? ,score = ? where id = ?";
183             ps = conn.prepareStatement(sql);
184             ps.setString(1, stu.getName());
185             ps.setInt(2, stu.getAge());
186             ps.setDouble(3, stu.getScore());
187             ps.setInt(4, stu.getId());
188             int count = ps.executeUpdate();
189             System.out.println(isSuccess(count));
190         } catch (Exception e) {
191             e.printStackTrace();
192         } finally {
193             try {
194                 if (null != ps) {
195                     ps.close();
196                 }
197                 if (null != conn) {
198                     conn.close();
199                 }
200             } catch (Exception e2) {
201                 e2.printStackTrace();
202             }
203         }
204     }
205 
206     /**
207      * 判断操作是否成功
208      */
209     public static String isSuccess(int count) {
210         if (count > 0) {
211             return "操作成功!";
212         } else {
213             return "操作失败!";
214         }
215     }
216 }

3:POJO实体类

 1 /**
 2  * 
 3  */
 4 package com.hlcui.entity;
 5 
 6 /**
 7  * @author Administrator
 8  * 
 9  */
10 public class Student {
11     private int id;
12     private String name;
13     private int age;
14     private double score;
15 
16     public Student() {
17 
18     }
19 
20     public Student(int id, String name, int age, double score) {
21         super();
22         this.id = id;
23         this.name = name;
24         this.age = age;
25         this.score = score;
26     }
27 
28     public int getId() {
29         return id;
30     }
31 
32     public void setId(int id) {
33         this.id = id;
34     }
35 
36     public String getName() {
37         return name;
38     }
39 
40     public void setName(String name) {
41         this.name = name;
42     }
43 
44     public int getAge() {
45         return age;
46     }
47 
48     public void setAge(int age) {
49         this.age = age;
50     }
51 
52     public double getScore() {
53         return score;
54     }
55 
56     public void setScore(double score) {
57         this.score = score;
58     }
59 
60 }

4:常量类Constants

 1 /**
 2  * 
 3  */
 4 package com.hlcui;
 5 
 6 /**
 7  * @author Administrator
 8  * 
 9  */
10 public class Constants {
11 
12     public static final String URL = "jdbc:mysql://localhost:3306/test";
13     public static final String USERNAME = "root";
14     public static final String PASSWORD = "root";
15 
16 }

 

四:测试类,验证是否能够操作数据库中数据

 1 /**
 2  * 
 3  */
 4 package com.hlcui.test;
 5 
 6 import java.sql.Connection;
 7 import java.sql.SQLException;
 8 import java.util.Iterator;
 9 import java.util.List;
10 
11 import org.junit.Test;
12 
13 import com.hlcui.Constants;
14 import com.hlcui.dao.DBUtil;
15 import com.hlcui.datasource.DataSourceUtil;
16 import com.hlcui.entity.Student;
17 
18 /**
19  * @author Administrator
20  * 
21  */
22 public class TestJdbc {
23 
24     /**
25      * 测试获取数据库连接
26      * 
27      * @throws SQLException
28      */
29     @Test
30     public void testGetConnection() throws SQLException {
31         Connection conn = DataSourceUtil.getConnection(Constants.URL,
32                 Constants.USERNAME, Constants.PASSWORD);
33         System.out.println("conn:" + conn);
34 
35     }
36 
37     /**
38      * 测试获取所有的学生信息
39      */
40     @Test
41     public void testGetAllStuInfo() {
42         List<Student> stus = DBUtil.getAllStuInfo();
43         Iterator<Student> it = stus.iterator();
44         while (it.hasNext()) {
45             Student s = it.next();
46             System.out.println(s.getId() + "," + s.getName() + "," + s.getAge()
47                     + "," + s.getScore());
48         }
49     }
50 
51     /**
52      * 测试根据id获取学生信息
53      */
54     @Test
55     public void testGetStuInfoById() {
56         int id = 1;
57         Student s = DBUtil.getStuInfoById(id);
58         System.out.println(s.getId() + "," + s.getName() + "," + s.getAge()
59                 + "," + s.getScore());
60     }
61 
62     /**
63      * 测试添加学生信息
64      */
65     @Test
66     public void testSaveStuInfo() {
67         Student s = new Student(4, "Lucy", 27, 100.0);
68         DBUtil.saveStuInfo(s);
69     }
70 
71     /**
72      * 测试删除学生信息
73      */
74     @Test
75     public void testDeleteStuInfo() {
76         int id = 4;
77         DBUtil.deleteStuInfo(id);
78     }
79     
80     /**
81      * 测试修改学生信息
82      */
83     @Test
84     public void testModifyStuInfo(){
85         Student s = new Student(3,"Lili",24,9000.0);
86         DBUtil.modifyStuInfo(s);
87     }
88 
89 }

以上代码均已验证正确。

以上是关于封装JDBC操作数据库的方法的主要内容,如果未能解决你的问题,请参考以下文章

一个JDBC封装工具类

JDBC数据库操作封装(PreparedStatement)

JDBC封装学习笔记---面向对象的JDBC

jdbc操作mysql:利用反射封装

DBUtils——用来完成jdbc的CRUD

Java操作数据库(四,JDBC的工具类封装及测试)