相信通过对小编前面的文章解析阅读与理解让读者有了一定的内容理解,下面就与小编一起进行更加深入的了解JDBC的工具类吧!
目录
JDBC工具类的封装
为什么要封装工具类?
封装的工具类(在同一个程序没有结束的工具类中,工具类只加载一次!!!)
?为什么工具类中的方法一般都是私有化的(!!!)?
封装驱动(使用配置文件,实现动态获取驱动)
封装数据库操作对象
封装释放资源(其他步骤也可以封装,看自己需要,一般情况封装上面三步骤)
为什么使用Statement不用PreparedStatement 来传入参数?
完整的JDB工具类代码
JDBC工具类的测试
JDBC工具类的封装
为什么要封装工具类?
为了方便后面开发的需要,我们需要封装一个工具类出来。
封装的工具类(在同一个程序没有结束的工具类中,工具类只加载一次!!!)
准备工作:在创建的jdbc文件夹下创建一个Utils(名称可以改,但最好有意义)的文件夹,创建一个JdbcUtil的工具类
准备好工具类,下面就可以开始代码的编写了
?为什么工具类中的方法一般都是私有化的(!!!)?
工具类中的方法私有化是为了防止工具类new对象,因为工具类的方法都是静态的,不需要new对象,直接使用类名称.方式调用(如图Arrays工具类一样)。
封装驱动(使用配置文件,实现动态获取驱动)
package com.luosf.jdbc.utils;
import java.sql.*;
import java.util.ResourceBundle;
/**
* 这个就是Jdbc的工具类
*
*/
public class JdbcUtil {
//Suppresses default constructor, ensuring non-instantiability.
//抑制默认构造函数,确保非实例化性。
private JdbcUtil(){
}
//使用静态变量,在类加载的时候执行,并且要在要在静态代码块前面(因为静态代码块要用)
//使用静态变量来实现动态注册驱动
private static ResourceBundle bundle = ResourceBundle.getBundle("resources/db");
//使用静态代码块:“保证注册驱动在类加载时执行,并且只执行一次”
//注册驱动
static{
try {
Class.forName(bundle.getString("driver"));
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
}
封装数据库操作对象
package com.luosf.jdbc.utils;
import java.sql.*;
import java.util.ResourceBundle;
/**
* 这个就是Jdbc的工具类
*
*/
public class JdbcUtil {
//Suppresses default constructor, ensuring non-instantiability.
//抑制默认构造函数,确保非实例化性。
private JdbcUtil(){
}
//使用静态变量,在类加载的时候执行,并且要在要在静态代码块前面(因为静态代码块要用)
//使用静态变量来实现动态注册驱动
private static ResourceBundle bundle = ResourceBundle.getBundle("resources/db");
//获取数据库链接对象,返回新的链接对象(一般情况下,外面有错误接受,所有直接抛出错误)
public static Connection getConnection() throws SQLException {
//从配置文件中获取需要的内容
String url = bundle.getString("url");
String user = bundle.getString("user");
String password = bundle.getString("password");
//获取数据库操作对象
Connection conn = DriverManager.getConnection(url,user,password);
//返回数据库操作对象
return conn;
}
}
封装释放资源(其他步骤也可以封装,看自己需要,一般情况封装上面三步骤)
package com.luosf.jdbc.utils;
import java.sql.*;
import java.util.ResourceBundle;
/**
* 这个就是Jdbc的工具类
*
*/
public class JdbcUtil {
//Suppresses default constructor, ensuring non-instantiability.
//抑制默认构造函数,确保非实例化性。
private JdbcUtil(){
}
//释放资源
//当不需要处理查询结果集是可以这样输入close(conn, stat, null)
public static void close(Connection conn, Statement stat, ResultSet res){
if (res != null){
try {
res.close();
} catch (SQLException throwables) {
throwables.printStackTrace();
}
}
if (stat != null){
try {
stat.close();
} catch (SQLException throwables) {
throwables.printStackTrace();
}
}
if (conn != null){
try {
conn.close();
} catch (SQLException throwables) {
throwables.printStackTrace();
}
}
}
}
为什么使用Statement不用PreparedStatement 来传入参数?
因为PreparedStatement是?Statement的子类,根据类的三大特性之一的多态性。多态性:同一个行为具有多个不同表现形式或形态的能力。所有使用Statement的能接受PreparedStatement的引用,反之,则不行。
完整的JDB工具类代码
package com.luosf.jdbc.utils;
import java.sql.*;
import java.util.ResourceBundle;
/**
* 这个就是Jdbc的工具类
*
*/
public class JdbcUtil {
//Suppresses default constructor, ensuring non-instantiability.
//抑制默认构造函数,确保非实例化性。
private JdbcUtil(){
}
//使用静态变量,在类加载的时候执行,并且要在要在静态代码块前面(因为静态代码块要用)
//使用静态变量来实现动态注册驱动
private static ResourceBundle bundle = ResourceBundle.getBundle("resources/db");
//使用静态代码块:“保证注册驱动在类加载时执行,并且只执行一次”
//注册驱动
static{
try {
Class.forName(bundle.getString("driver"));
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
//获取数据库链接对象,返回新的链接对象(一般情况下,外面有错误接受,所有直接抛出错误)
public static Connection getConnection() throws SQLException {
//从配置文件中获取需要的内容
String url = bundle.getString("url");
String user = bundle.getString("user");
String password = bundle.getString("password");
//获取数据库操作对象
Connection conn = DriverManager.getConnection(url,user,password);
//返回数据库操作对象
return conn;
}
//释放资源
//当不需要处理查询结果集是可以这样输入close(conn, stat, null)
public static void close(Connection conn, Statement stat, ResultSet res){
if (res != null){
try {
res.close();
} catch (SQLException throwables) {
throwables.printStackTrace();
}
}
if (stat != null){
try {
stat.close();
} catch (SQLException throwables) {
throwables.printStackTrace();
}
}
if (conn != null){
try {
conn.close();
} catch (SQLException throwables) {
throwables.printStackTrace();
}
}
}
}
JDBC工具类的测试
竟然工具类已经封装好了下面就可以开始,使用并测试代码是否能正常运行吧!
package com.luosf.jdbc;
import com.luosf.jdbc.utils.JdbcUtil;
import java.sql.*;
/**
* JDBC工具类的测试类
*/
public class JdbcUtilTest {
public static void main(String[] args) {
Connection conn = null;
PreparedStatement stat = null;
ResultSet res = null;
try {
//1,类加载时就已经注册驱动
//2,获取链接
conn = JdbcUtil.getConnection();
//sql指令
String sql = "select * from t_shuihuo where id < ? ";
//3,sql语句进行编译
stat = conn.prepareStatement(sql);
//给占位符填充值
//JDBC下标从1开始的
stat.setInt(1,16); //1,代表第一个问号
System.out.println(sql);
//4,执行sql
res = stat.executeQuery();
//5,处理查询结果集
while (res.next()){
int id = res.getInt("id");
String name = res.getString("name");
String nickname = res.getString("nickname");
System.out.println("id :"+ id + " name :" +name + " 昵称 :"+nickname);
}
} catch (SQLException throwables) {
throwables.printStackTrace();
}finally {
//6,释放资源
JdbcUtil.close(conn,stat,res);
//当没有查询结果集时,传入null
// JdbcUtil.close(conn,stat,null);
}
}
}
?
|