zoukankan      html  css  js  c++  java
  • SpringJDBC解析4-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());  

  • 相关阅读:
    转:C++中Static作用和使用方法
    转:C/C++中,空数组、空类、类中空数组的解析及其作用
    转:c++类实例在内存中的分配
    转:union 联合体(共用体)
    转:内存对齐与补齐 字节对齐与结构体大小
    转:c++内存分配
    转:代码重构
    转:设计模式六大原则(3):依赖倒置原则
    读书
    转:Teach Yourself Programming in Ten Years——用十年教会自己编程
  • 原文地址:https://www.cnblogs.com/wade-luffy/p/6080011.html
Copyright © 2011-2022 走看看