JDBC获取数据库Connection的工具抽取

时间:2021-03-24 20:12:13

使用JDBC获取数据库的连接,大字分为三个步骤

1、获取驱动包名,定义URL,database_username,database_password

2、获取Connection对象

3、利用Connection对象获取Statement或者PreparedStatement对象

4、再调用PreparedStatement对象的executeQuery()、executeUpdate()方法去进行操作

5、释放对象和资源

这5步都比较繁琐,特别是第1步,其中耦合度比较低的是的是第1步,第2步。

通用的做法是将获取Connection对象的过程单独抽出来,做成工具,以后使用的时候直接调用就行。

但是又需要在系统启动的时候就将配置文件读进来,并且不反复读取,就只有使用静态代码块static{}了。

同理,获取驱动包的操作也是,执行一次就够了。

第5步释放对象和资源,其实也可以抽象出来,如果执行的是executeUpdate(),关闭两个对象,如果执行的是查询语句,多关闭一个result对象就可以了。


此处强烈推荐使用连接池,每次自己获取Connection对象,容易出错,也繁琐。推荐使用c3p0


jdbc.properties配置文件内容

driverClass=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/loginpractice
username=root
password=1234

JdbcUtils源码

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.ResourceBundle;

public class JdbcUtils {
        //1、创建四个常量 DRIVERCLASS URL DATABASE PASSWORD
        //2、构建静态代码块,读取配置文件,给常量赋值
        //3、获取Connection对象
        private static final String DRIVERCLASS;
        private static final String URL;
        private static final String USERNAME;
        private static final String PASSWORD;
        static {//读取配置文件
            DRIVERCLASS = ResourceBundle.getBundle("jdbc").getString("driverClass");
            URL = ResourceBundle.getBundle("jdbc").getString("url");
            USERNAME = ResourceBundle.getBundle("jdbc").getString("username");
            PASSWORD = ResourceBundle.getBundle("jdbc").getString("password");
        }
        static {
            try {// 将加载驱动操作,放置在静态代码块中.这样就保证了只加载一次.
                Class.forName(DRIVERCLASS);
            } catch (ClassNotFoundException e) {
                e.printStackTrace();
            }
        }
        public static Connection getConnection() throws SQLException {
            // 2.获取连接
            Connection con = DriverManager.getConnection(URL, USERNAME, PASSWORD);
            System.out.println("获取连接成功");
            return con;
        }
}