Java操作数据库(四,JDBC的工具类封装及测试)
Posted 韶光不负
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java操作数据库(四,JDBC的工具类封装及测试)相关的知识,希望对你有一定的参考价值。
相信通过对小编前面的文章解析阅读与理解让读者有了一定的内容理解,下面就与小编一起进行更加深入的了解JDBC的工具类吧!
目录
封装的工具类(在同一个程序没有结束的工具类中,工具类只加载一次!!!)
封装释放资源(其他步骤也可以封装,看自己需要,一般情况封装上面三步骤)
为什么使用Statement不用PreparedStatement 来传入参数?
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);
以上是关于Java操作数据库(四,JDBC的工具类封装及测试)的主要内容,如果未能解决你的问题,请参考以下文章
Java 中封装JDBC连接到JDBCUtils工具类的详解
JDBC(本质,配置环境变量,JDBC编程六步,类加载注册,sql注入,事务问题,封装工具类,悲观锁,乐观锁)
Java 中封装JDBC连接到JDBCUtils工具类的详解