JDBCTemplate基本使用和使用方法。

文章目录

  • 前言
  • 一、使用步骤
    • 1、导入jar包
    • 2、常用方法
    • 3、代码示例
  • 总结


前言

   JDBCTamplate是Spring框架对JDBC的简单封装。提供了一个JDBCTemplate对象简         化JDBC的开发。JDBCTemplate依赖于数据源DataSource 。创建JDBCTemplate对象,只需要new一个JDBCTemplate,然后将我们在JDBCUtils创建的连接池对象DataSource作为参数传入即可。例如:JDBCTemplate template = new jdbcTemplate(DataSource);


一、使用步骤

1.导入jar包

在使用JDBCTemplate之前,需要导入相关的jar包,因为在这我使用的是c3p0  jdbcTemplate ,所以需要导入JDBCTemplate jar包5个+c3p0 jar包2个 + 数据库驱动包。

导入的jar包有如下(示例):

2.常用方法

调用JDBCTemplate的方法来完成CRUD的操作

>1. update():执行DML语句。增删改语句。
> 2. queryForMap():将查询结果将结果集封装为map集合,将列名作为key,将值作为value,将这条记录封装为一个map集合。    
 注:查询的结果集长度只能是1。
> 3. queryForList():查询结果将结果集封装为List集合。
注:将每一条记录封装为一个Map集合,再将Map集合装载到List集合中。
>4. query():查询结果,将结果封装为JavaBean对象的list集合中。
>5. queryForObject:查询结果,将结果封装为对象。

3.代码示例

JdbcUtils工具类:


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;

/*
    1. 声明静态数据源成员变量
    2. 创建连接池对象
    3. 定义公有的得到数据源的方法
    4. 定义得到连接对象的方法
    5. 定义关闭资源的方法
 */
public class JDBCUtils {
    // 1.    声明静态数据源成员变量
    private static DataSource ds;

    // 2. 创建连接池对象
    static {
        // 加载配置文件中的数据
        InputStream is = JDBCUtils.class.getClassLoader().getResourceAsStream("druid.properties");
        Properties pp = new Properties();
        try {
            pp.load(is);
            // 创建连接池,使用配置文件中的参数
            ds = DruidDataSourceFactory.createDataSource(pp);
        } catch (IOException e) {
            e.printStackTrace();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    // 3. 定义公有的得到数据源的方法
    public static DataSource getDataSource() {
        return ds;
    }

    // 4. 定义得到连接对象的方法
    public static Connection getConnection() throws SQLException {
        return ds.getConnection();
    }

    // 5.定义关闭资源的方法
    public static void close(Connection conn, Statement stmt, ResultSet rs) {
        if (rs != null) {
            try {
                rs.close();
            } catch (SQLException e) {}
        }

        if (stmt != null) {
            try {
                stmt.close();
            } catch (SQLException e) {}
        }

        if (conn != null) {
            try {
                conn.close();
            } catch (SQLException e) {}
        }
    }

    // 6.重载关闭方法
    public static void close(Connection conn, Statement stmt) {
        close(conn, stmt, null);
    }
}

JDBCTemplate实现类:

public class DaoRouteImpl implements DaoRoute {
    private JdbcTemplate template = new JdbcTemplate(JDBCUtils.getDataSource());
    @Override
    public int findTotalCount(int cid) {
        String sql = "select count(*) from tab_route where cid = ?";
        return template.queryForObject(sql, Integer.class, cid);
    }

    @Override
    public List<Route> findByPage(int cid, int start, int pageSize) {
        String sql = "select * from tab_route where cid = ? limit ? , ?";
        return template.query(sql, new BeanPropertyRowMapper<Route>(Route.class), cid, start, pageSize);
    }

}

总结

       使用jdbc连接池之后,我们会发现连接对象的复用性更高了,程序整体运行的性能也更高了。但我们发现操作JDBC还是比较麻烦的,要定义SQL,执行SQL,设置参数,处理结果。而JDBCTemplate却帮我们大大的减少了我们所需的工作量。

猜你喜欢

转载自blog.csdn.net/weixin_51012090/article/details/118880270