文档章节

iBATIS获取真正执行SQL

谢雨齐
 谢雨齐
发布于 2016/04/18 09:59
字数 296
阅读 123
收藏 0

最近项目上有一需求,获取ibatis执行的sql,注意是可以贴到客户端直接执行的SQL,搜索引擎加API查看,找到如下方式(废话不多说,直接上代码):

import com.ibatis.sqlmap.engine.impl.SqlMapClientImpl;
import com.ibatis.sqlmap.engine.mapping.parameter.ParameterMap;
import com.ibatis.sqlmap.engine.mapping.parameter.ParameterMapping;
import com.ibatis.sqlmap.engine.mapping.sql.Sql;
import com.ibatis.sqlmap.engine.mapping.statement.MappedStatement;
import com.ibatis.sqlmap.engine.scope.SessionScope;
import com.ibatis.sqlmap.engine.scope.StatementScope;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.springframework.orm.ibatis.SqlMapClientTemplate;
 
public class IBatisUtil {
    private static Log log = LogFactory.getLog(IBatisUtil.class);
    /**
     * 获取当前执行的sql
     * @param template
     * @param sqlName
     * @param param
     * @return
     */
    public static String getCurrentSql(SqlMapClientTemplate template, String sqlName, Object param){
        String sql = "";
        SqlMapClientImpl sqlmap = (SqlMapClientImpl)template.getSqlMapClient();
        MappedStatement stmt = sqlmap.getMappedStatement(sqlName);
        Sql stmtSql = stmt.getSql();
        SessionScope sessionScope = new SessionScope();
        StatementScope statementScope = new StatementScope(sessionScope);
        statementScope.setStatement(stmt);
        sql = stmtSql.getSql(statementScope, param);
        ParameterMap parameterMap = stmtSql.getParameterMap(statementScope, param);
        Object[] objs = null;
        if(parameterMap != null){
            objs = parameterMap.getParameterObjectValues(statementScope, param);
        }
        ParameterMapping[] parameterMappings = parameterMap.getParameterMappings();
        log.debug("[ignite]parameterMappings length=" + parameterMappings.length);
        for (int i = 0; i < parameterMappings.length; i++) {
            log.debug("[ignite]parameterName=" + parameterMappings[i].getPropertyName() + "; parameterValue=" + objs[i]);
        }
        return getPreparedSql(sql, objs);
    }
    public static String getPreparedSql(String sql, Object[] params){
        //1 如果没有参数,说明是不是动态SQL语句
        int paramNum = 0;
        if (null != params) paramNum = params.length;
        if (1 > paramNum) return sql;
        //2 如果有参数,则是动态SQL语句
        StringBuffer stringBuffer = new StringBuffer();
        String[] subsql = sql.split("\\?");
        for (int i = 0; i < paramNum; i++) {
            if(params[i] instanceof Integer){
                stringBuffer.append(subsql[i]).append(" ").append(params[i]).append(" ");
            }else{
                stringBuffer.append(subsql[i]).append(" '").append(params[i]).append("' ");
            }
        }
        if (subsql.length > params.length) {
            stringBuffer.append(subsql[subsql.length - 1]);
        }
        return stringBuffer.toString();
    }
}

© 著作权归作者所有

共有 人打赏支持
上一篇: Resin4 日志配置
下一篇: 记一次 HTTPS升级
谢雨齐
粉丝 0
博文 15
码字总数 2188
作品 0
东城
程序员
私信 提问
加载中

评论(1)

i
itxx2016
推荐国内最流行的ibatis代码生成网站 --- fwjava.com
无需任何安装配置,直接在线生成,且十分规范好用.
现在,很多知名的互联网公司都在用它.
深入分析 iBATIS 框架之系统架构与映射原理

简介: iBATIS 通过 SQL Map 将 Java 对象映射成 SQL 语句和将结果集再转化成 Java 对象,与其他 ORM 框架相比,既解决了 Java 对象与输入参数和结果集的映射,又能够让用户方便的手写使用 ...

老盖
2010/11/11
2.2K
3
[IBM DW] 深入分析 iBATIS 框架之系统架构与映射原理

简介: iBATIS 通过 SQL Map 将 Java 对象映射成 SQL 语句和将结果集再转化成 Java 对象,与其他 ORM 框架相比,既解决了 Java 对象与输入参数和结果集的映射,又能够让用户方便的手写使用 ...

红薯
2010/11/13
1K
2
凤凰涅槃:从 iBatis 到 MyBatis

简介: 本文主要讲述了 iBatis 2.x 和 MyBatis 3.0.x 的区别,以及从 iBatis 向 MyBatis 移植时需要注意的地方。通过对本文的学习,读者基本能够了解 MyBatis 有哪些方面的改进,并能够顺利使...

IBMdW
2011/06/24
1K
2
从 iBatis 到 MyBatis,你准备好了吗?

对于从事 Java EE 的开发人员来说,iBatis 是一个再熟悉不过的持久层框架了,在 Hibernate、JPA 这样的一站式对象 / 关系映射(O/R Mapping)解决方案盛行之前,iBaits 基本是持久层框架的不...

被风遗忘
2012/03/30
0
0
凤凰涅槃:从 iBatis 到 MyBatis.

从 iBatis 到 MyBatis,你准备好了吗? 对于从事 Java EE 的开发人员来说,iBatis 是一个再熟悉不过的持久层框架了,在 Hibernate、JPA 这样的一站式对象 / 关系映射(O/R Mapping)解决方案...

被风遗忘
2012/04/18
0
1

没有更多内容

加载失败,请刷新页面

加载更多

Spring Security 实现 antMatchers 配置路径的动态获取

1. 为什么要实现动态的获取 antMatchers 配置的数据 这两天由于公司项目的需求,对 spring security 的应用过程中需要实现动态的获取 antMatchers ,permitAll , hasAnyRole , hasIpAddre...

大木老师故事的小黄花
15分钟前
19
0
Java 内存模型

一、Java内存模型 硬件处理 电脑硬件,我们知道有用于计算的cpu、辅助运算的内存、以及硬盘还有进行数据传输的数据总线。在程序执行中很多都是内存计算,cpu为了更快的进行计算会有高速缓存,...

微笑向暖wx
16分钟前
0
0
Maven shade的使用

有时你的工程里会和你的Spark环境出现包冲突,这时候可以用Maven shade将你的包名重命名,在maven里加上: <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-shade......

守望者之父
17分钟前
0
0
SpringBoot中导入Excel的总结

1 先导入配置文件 <dependency><groupId>org.apache.poi</groupId><artifactId>poi</artifactId></dependency><dependency><groupId>org.apache.poi</groupI......

小小小施爷
17分钟前
0
0
python是如何进行内存管理的

Python引入了一个机制:引用计数。 python内部使用引用计数,来保持追踪内存中的对象,Python内部记录了对象有多少个引用,即引用计数,当对象被创建时就创建了一个引用计数,当对象不再需要...

糖宝lsh
20分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部