zoukankan      html  css  js  c++  java
  • 关于SpringBoot集成JDBCTemplate的RowMapper问题

          JdbcTemplate 是Spring提供的一套JDBC模板框架,利用AOP 技术来解决直接使用JDBC时大量重复代码的问题。JdbcTemplate虽然没有MyBatis 那么灵活,但是直接使用JDBC要方便很多。Spring Boot中对Jdbc Template的使用提供了自动化配置类JdbcTemplateAutoConfiguration,部分源码如下:

    View Code

      从上面这段源码中可以看出,当classpath下存在DataSource和JdbcTemplate 并且DataSource只有一个实例时,自动配置才会生效,若开发者没有提供JdbcOperations,则Spring Boot会自动向容器中注入一个JdbcTemplate(Jdbc Template是JdbcOperations的子类)。由此可以看到,开发者想要使用Jdbc Template,只需要提供JdbcTemplate的依赖和DataSource依赖即可。具体操作步骤

    1,创建数据库表并插入数据  

    View Code

    2,添加依赖

    View Code

    3.数据库配置(注意数据库的配置)
    在application.properties中配置数据库基本连接信息:

    View Code

    4.创建实体类,

    创建Book实体类,代码如下:

    View Code

    5.创建数据库访问层

    View Code

    代码解释:

    创建BookDao,注入Jdbc Template。由于已经添加了spring-jdbc相关的依赖,JdbcTemplate会被自动注册到Spring容器中,因此这里可以直接注入Jdbc Template使用。在JdbcTemplate中,增删改三种类型的操作主要使用update和batchUpdate方法来完成。query和queryForObject方法主要用来完成查询功能。另外,还有execute方法可以用来执行任意的SQL、cal方法用来调用存储过程等。·在执行查询操作时,需要有一个/RowMapper f查询出来的列和实体类中的属性一一对应起)来。如果列名和属性名都是相同的,那么可以直接使用BeanPropertyRowMapper;如果列名和属性名不同就需要开发者自己实见RowMapper 接口,将列和实体类属性一一对应起来。

    6.创建Service和Controller
    创建BookService和BookController,代码如下:

    BookService

    View Code

    BookController

    View Code

    最后,在浏览器中访问http://localhost:8080/bookOps地址,控制台打印日志如图5-1所示
    addBook>〉>1
    updateBoolk>〉>1
    getBookById>>>Book{id=1,name='朝花夕拾’,author='鲁迅’}
    deleteBoolkById>>>1
    getA11Books>>>[Book{id=1,name='朝花夕拾’,author='鲁迅’},Book{id=4,name='西厢记’,author='王实甫’}]

      这里只是介绍SpringBoot集成JDBCTemplate的Demo,重点在于上面说的这句话“·在执行查询操作时,需要有一个/RowMapper f查询出来的列和实体类中的属性一一对应起)来。如果列名和属性名都是相同的,那么可以直接使用BeanPropertyRowMapper;如果列名和属性名不同就需要开发者自己实见RowMapper 接口,将列和实体类属性一一对应起来。”

      那么在上面我们看到,JdbcTemplate已经封装了对应增删改的方法,我们只需直接调用即可,关键在于query查询时候RowMapper的这点上,正如上面所说,如果列名和属性名都是相同的,我们可以直接使用BeanPropertyRowMapper,如果列名和属性名不同就需要开发者自己实见RowMapper 接口,将列和实体类属性一一对应起来。”

      那么到底这个RowMapper是什么 ,官方的源码如下

    package org.springframework.jdbc.core;
    
    import java.sql.ResultSet;
    import java.sql.SQLException;
    import org.springframework.lang.Nullable;
    
    @FunctionalInterface
    public interface RowMapper<T> {
        @Nullable
        T mapRow(ResultSet var1, int var2) throws SQLException;
    }

      不难看出这是一个方法接口 ,里面的抽象法中的ResultSet又是什么呢 ,表示数据库结果集的数据表,通常由执行查询数据库的语句生成,这里我只贴出官方的版本,想看的直接点击ctrl+鼠标左键点进去看,我用的是IDEA

    View Code

      如何实现自己的RowMapper?参照如下代码

    public class BeanRowMapper implements RowMapper<Article> {
      //这里的类名只是为了掩饰   根据自己的情况修改
        @Override
        public Article mapRow(ResultSet resultSet, int i) throws SQLException {
            Bean bean= new Bean();
          //设置不一致的列名与实体字段对应 bean.setId(resultSet.getInt("id")); bean.setTitle(resultSet.getString("title")); bean.setDescription(resultSet.getString("description")); return Bean; } }

      然后修改对应的Dao代码

    /**
     * 查询所有数据
     */
    public List<Bean> findAll() {
        String sql = "SELECT id, title, description FROM Bean";
        return jdbcTemplate.query(sql, new BeanRowMapper());
    }
    
    /**
     * 查询单条数据
     */
    public BeanfindById(Integer id) {
        String sql = "SELECT id, title, description FROM BeanWHERE id = ?";
        return jdbcTemplate.queryForObject(sql, new BeanRowMapper());
    }

      然后在测试对应的接口

    才疏学浅,有错误请指出

        

    新鲜刺激的东西永远都有,玩之前掂量掂量自己几斤几两
  • 相关阅读:
    Lua语言基础汇总(9)-- Lua中__index和__newindex实践
    Lua语言基础汇总(8) -- Lua中的元表与元方法
    Lua语言基础汇总(7) -- 协同程序
    Lua语言基础汇总(6)-- 迭代器与泛型for
    Lua语言基础汇总(5) -- 闭包
    【NOIP2005提高组T2】过河-DP+路径压缩
    【NOIP2005提高组T2】过河-DP+路径压缩
    【NOIP2002提高组T2】字串变换-双向BFS或迭代加深搜索
    【NOIP2002提高组T2】字串变换-双向BFS或迭代加深搜索
    【NOIP2001提高组T2】数的划分-DP
  • 原文地址:https://www.cnblogs.com/banxianer/p/12270113.html
Copyright © 2011-2022 走看看