iBATIS获取真正执行SQL

最近项目上有一需求,获取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();
    }
}

转载于:https://my.oschina.net/jiyuefeng/blog/661604

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值