将JDBCUtils工具类改成Druid实现

本文介绍了如何将原有的JDBCUtils工具类替换为Druid数据库连接池,提供getConnection(),close()等方法,并展示了在测试类中使用Druid进行CRUD操作的示例。
摘要由CSDN通过智能技术生成

将JDBCUtils工具类改成Druid实现

public class Druid {
    private static DataSource ds;

    //在静态代码块中完成初始化
    static {

        try {
            //创建Properties
            Properties properties = new Properties();
            properties.load(new FileInputStream("src/druid.properties"));
            //创建一个指定参数的数据库连接池
            ds = DruidDataSourceFactory.createDataSource(properties);
        } catch (Exception e) {
            throw new RuntimeException(e);
        }
    }

    //获得连接
    public static Connection getConnection() throws SQLException {
        return ds.getConnection();
    }

    //关闭连接--在数据库连接池技术中,close 不是真正的断掉连接,而是使用Connection对象将连接放回连接池中
    // 可能需要关闭的资源resultSet,statement或者PreperedStatement,Connectin
    public static void close(ResultSet set, Statement statement, Connection connection) {
        try {
            if (set != null) {
                set.close();
            }
            if (statement != null) {
                statement.close();
            }
            if (connection != null) {
                connection.close();
            }
        } catch (SQLException e) {
            //将编译异常转成运行异常,调用者可以选择捕获该异常,也可以选择默认处理
            throw new RuntimeException(e);
        }
    }
}

测试

public class UseDruid {
    public static void main(String[] args) {

    }
    @Test
    public void update() throws Exception {
        // 得到连接
        Connection connection = Druid.getConnection();
        // 组织sql语句
        String update="update actor set `name`=? where id=?";
        // 创建PreparedStatement
        PreparedStatement preparedStatement = connection.prepareStatement(update);
        //给占位符赋值
        preparedStatement.setString(1,"新关晓彤");
        preparedStatement.setInt(2,3);

        // 执行Sql
        preparedStatement.executeUpdate();
        // 关闭连接
        Druid.close(null,preparedStatement,connection);
    }
    @Test
    public void insert() throws Exception {
        // 得到连接
        Connection connection = Druid.getConnection();
        // 组织sql语句
        String insert="INSERT INTO actor VALUES(NULL,?,?,?,?)";
        // 创建PreparedStatement
        PreparedStatement preparedStatement = connection.prepareStatement(insert);
        //给占位符赋值
        preparedStatement.setString(1,"李四");
        preparedStatement.setString(2,"男");
        preparedStatement.setString(3,"1999-08-04");
        preparedStatement.setString(4,"114");
        // 执行Sql
        preparedStatement.executeUpdate();
        // 关闭连接
        Druid.close(null,preparedStatement,connection);
    }
    @Test
    public void delete() throws Exception {
        // 得到连接
        Connection connection = Druid.getConnection();
        // 组织sql语句
        String delete="delete from actor where id=?";
        // 创建PreparedStatement
        PreparedStatement preparedStatement = connection.prepareStatement(delete);
        //给占位符赋值
        preparedStatement.setInt(1,2);
        // 执行Sql
        preparedStatement.executeUpdate();
        // 关闭连接
        Druid.close(null,preparedStatement,connection);
    }

    @Test
    public void select() throws Exception {
        // 得到连接
        Connection connection = Druid.getConnection();
        // 组织sql语句
        String select="select id,name from actor";
        // 创建PreparedStatement
        PreparedStatement preparedStatement = connection.prepareStatement(select);
        // 执行Sql
        ResultSet resultSet = preparedStatement.executeQuery();
        //将查询结果打印到控制台
        while(resultSet.next()){
            int id = resultSet.getInt(1);
            String name = resultSet.getString(2);
            System.out.println(id+"\t"+name);
        }
        // 关闭连接
        Druid.close(null,preparedStatement,connection);
    }

}

package druidJDBCUtils; import com.alibaba.druid.pool.DruidDataSourceFactory; import javax.sql.DataSource; import java.io.IOException; import java.io.InputStream; import java.sql.Connection; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import java.util.Properties; public class DruidJDBCUtils { //定义成员变量 private static DataSource ds; //静态代码块加载配置文件 static { try { Properties prop = new Properties(); InputStream is = DruidJDBCUtils.class.getClassLoader().getResourceAsStream("druid.properties"); prop.load(is); ds = DruidDataSourceFactory.createDataSource(prop); } catch (IOException e) { e.printStackTrace(); } catch (Exception e) { e.printStackTrace(); } } /** * 获取数据库连接对象 */ public static Connection getConnection() throws SQLException { return ds.getConnection(); } /** * 获取连接池方法 */ public static DataSource getDataSource(){ return ds; } /** * 关闭资源方法 * close()查询sql方法 */ public static void close(ResultSet resultSet, Statement statement, Connection connection) { if (resultSet != null) { try { resultSet.close(); } catch (SQLException e) { e.printStackTrace(); } } if (statement != null) { try { statement.close(); } catch (SQLException e) { e.printStackTrace(); } } if (connection != null) { try { connection.close(); } catch (SQLException e) { e.printStackTrace(); } } } /** * 关闭资源方法 * close()增删改sql方法 */ public static void close(Statement statement, Connection connection) {
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值