SpringJDBC解析4-query方法

简介: 重要步骤说明: 首先是从PersonServiceImpl方法进去,调用JdbcTemplate的query方法,然后执行一连串错中复杂的调用,而且里面有很多函数都是以回调形式处理, 1)JdbcTemplate接受到query请求,由于query没有带参数,所以选择不带sql参数的重载方法query执行。

重要步骤说明:

首先是从PersonServiceImpl方法进去,调用JdbcTemplate的query方法,然后执行一连串错中复杂的调用,而且里面有很多函数都是以回调形式处理,
1)JdbcTemplate接受到query请求,由于query没有带参数,所以选择不带sql参数的重载方法query执行。
2)query方法面会创建一个内部类(QueryStatementCallback),然后实例化,传给execute方法,等待execute回调。
3)上面是传了一个callback对象的实例进入execute,其实execute也是JdbcTemplate的核心方法,虽然execute有很多重载方法,但是他们的核心逻辑其实没什么特别大的差别。

4)获取到List对象后,就直接退出execute方法,逐步返回result,知道返回给最初的调用者

其他概念详见SpringJDBC解析前面的系列,这里着重看一下回调函数

public <T> T query(final String sql, final ResultSetExtractor<T> rse) throws DataAccessException {  
    Assert.notNull(sql, "SQL must not be null");  
    Assert.notNull(rse, "ResultSetExtractor must not be null");  
    if (logger.isDebugEnabled()) {  
        logger.debug("Executing SQL query [" + sql + "]");  
    }  
    class QueryStatementCallback implements StatementCallback<T>, SqlProvider {  
        public T doInStatement(Statement stmt) throws SQLException {  
            ResultSet rs = null;  
            try {  
                rs = stmt.executeQuery(sql);  
                ResultSet rsToUse = rs;  
                if (nativeJdbcExtractor != null) {  
                    rsToUse = nativeJdbcExtractor.getNativeResultSet(rs);  
                }  
                //先进入RowMapperResultSetExtractor的回调函数,然后再回调PersonRowMapper的mapRow方法  
                return rse.extractData(rsToUse);  
            }  
            finally {  
                JdbcUtils.closeResultSet(rs);  
            }  
        }  
        public String getSql() {  
            return sql;  
        }  
    }  
    return execute(new QueryStatementCallback());  

 

 

目录
相关文章
|
30天前
|
机器学习/深度学习 存储 PyTorch
Pytorch中in-place操作相关错误解析及detach()方法说明
Pytorch中in-place操作相关错误解析及detach()方法说明
41 0
|
1月前
|
存储 开发框架 开发者
QT C++焦点事件:多角度解析实用技巧与方法
QT C++焦点事件:多角度解析实用技巧与方法
146 0
|
1月前
|
敏捷开发 开发框架 数据可视化
|
1月前
|
C语言
【C语言】大小写字母的相互转化:多种方法解析及原理说明
【C语言】大小写字母的相互转化:多种方法解析及原理说明
106 0
|
1月前
|
机器学习/深度学习 数据采集 自然语言处理
岭回归与LASSO回归:解析两大经典线性回归方法
岭回归与LASSO回归:解析两大经典线性回归方法
岭回归与LASSO回归:解析两大经典线性回归方法
|
2天前
|
SQL 分布式计算 资源调度
一文解析 ODPS SQL 任务优化方法原理
本文重点尝试从ODPS SQL的逻辑执行计划和Logview中的执行计划出发,分析日常数据研发过程中各种优化方法背后的原理,覆盖了部分调优方法的分析,从知道怎么优化,到为什么这样优化,以及还能怎样优化。
|
2天前
并发编程之Callable方法的详细解析(带小案例)
并发编程之Callable方法的详细解析(带小案例)
10 0
|
21天前
|
存储 缓存 监控
深入解析linux内存指标:快速定位系统内存问题的有效技巧与实用方法(free、top、ps、vmstat、cachestat、cachetop、sar、swap、动态内存、cgroops、oom)
深入解析linux内存指标:快速定位系统内存问题的有效技巧与实用方法(free、top、ps、vmstat、cachestat、cachetop、sar、swap、动态内存、cgroops、oom)
|
21天前
|
存储 算法
从动态规划到贪心算法:最长递增子序列问题的方法全解析
从动态规划到贪心算法:最长递增子序列问题的方法全解析
20 2
|
28天前
|
算法 项目管理 开发者
【Conan 入门教程 】深入解析Conan中的依赖关系的定义方法(In-depth Analysis of Dependency Definition Methods in Conan)
【Conan 入门教程 】深入解析Conan中的依赖关系的定义方法(In-depth Analysis of Dependency Definition Methods in Conan)
38 0

推荐镜像

更多