mybatis xml怎么打印sql

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mybatis xml怎么打印sql相关的知识,希望对你有一定的参考价值。

参考技术A 想要打印工程项目中所有sql并判断是否带有where条件就比较明晰了,直接上代码:
@Resource
private SqlSessionFactory sqlSessionFactory;
@Test
public void test_check()
Configuration configuration = sqlSessionFactory.getConfiguration();
System.out.println("#sql.size#" + configuration.getMappedStatements().size());
Set<String> errors = Sets.newHashSet();
int i = 1;
for (Object obj : configuration.getMappedStatements())
if (obj instanceof MappedStatement)
MappedStatement mappedStatement = (MappedStatement) obj;
String sql = mappedStatement.getSqlSource().getBoundSql(new SqlParamMap()).getSql();
sql = sql.replaceAll("\n", "");
sql = sql.replaceAll("\\s+", " ");
System.out.println(String.format("#sql,#%02d #%s #%s", i++, mappedStatement.getSqlCommandType(), sql));
if (!sql.toLowerCase().startsWith("insert") && !sql.toLowerCase().startsWith("select")
&& !sql.toLowerCase().startsWith("replace"))
if (!sql.toLowerCase().contains("where"))
errors.add(sql);




System.err.println("#error#" + errors.size());
for (String errorSql : errors)
System.err.println(errorSql);



// 这里为了方便生成sql时,解析入参对象的
public static class SqlParamMap extends AbstractMap<String, Object> implements Map<String, Object>
@Override
public Set<Entry<String, Object>> entrySet()
return Collections.emptySet();

@Override
public Object get(Object key)
return new Object[] 1, 2;

Mybatis日志打印Sql

配置mybatis-config.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration
    PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
    "http://mybatis.org/dtd/mybatis-3-config.dtd">

<configuration>
    
 
    <plugins>                                                
         <plugin interceptor="MybatisInterceptor"></plugin>  
    </plugins>
</configuration>

 

新建JAVA类 MybatisInterceptor 

import java.text.DateFormat;  
import java.util.Date;  
import java.util.List;  
import java.util.Locale;  
import java.util.Properties;  
   
import org.apache.ibatis.executor.Executor;  
import org.apache.ibatis.mapping.BoundSql;  
import org.apache.ibatis.mapping.MappedStatement;  
import org.apache.ibatis.mapping.ParameterMapping;  
import org.apache.ibatis.plugin.Interceptor;  
import org.apache.ibatis.plugin.Intercepts;  
import org.apache.ibatis.plugin.Invocation;  
import org.apache.ibatis.plugin.Plugin;  
import org.apache.ibatis.plugin.Signature;  
import org.apache.ibatis.reflection.MetaObject;  
import org.apache.ibatis.session.Configuration;  
import org.apache.ibatis.session.ResultHandler;  
import org.apache.ibatis.session.RowBounds;  
import org.apache.ibatis.type.TypeHandlerRegistry;  
   
@Intercepts({  
        @Signature(type = Executor.class, method = "update", args = { MappedStatement.class, Object.class }),  
        @Signature(type = Executor.class, method = "query", args = { MappedStatement.class, Object.class,  
                RowBounds.class, ResultHandler.class }) })  
public class MybatisInterceptor implements Interceptor {  
   
    private Properties properties;  
   
    public Object intercept(Invocation invocation) throws Throwable {  
        MappedStatement mappedStatement = (MappedStatement) invocation.getArgs()[0];  
        Object parameter = null;  
        if (invocation.getArgs().length > 1) {  
            parameter = invocation.getArgs()[1];  
        }  
        String sqlId = mappedStatement.getId();  
        BoundSql boundSql = mappedStatement.getBoundSql(parameter);  
        Configuration configuration = mappedStatement.getConfiguration();  
        Object returnValue = null;  
        long start = System.currentTimeMillis();  
        returnValue = invocation.proceed();  
        long end = System.currentTimeMillis();  
        long time = (end - start);  
        if (time > 1) {  
            String sql = getSql(configuration, boundSql, sqlId, time);  
            System.err.println(sql);  
        }  
        return returnValue;  
    }  
   
    public static String getSql(Configuration configuration, BoundSql boundSql, String sqlId, long time) {  
        String sql = showSql(configuration, boundSql);  
        StringBuilder str = new StringBuilder(100);  
        str.append(sqlId);  
        str.append(":");  
        str.append(sql);  
        str.append(":");  
        str.append(time);  
        str.append("ms");  
        return str.toString();  
    }  
   
    private static String getParameterValue(Object obj) {  
        String value = null;  
        if (obj instanceof String) {  
            value = "‘" + obj.toString() + "‘";  
        } else if (obj instanceof Date) {  
            DateFormat formatter = DateFormat.getDateTimeInstance(DateFormat.DEFAULT, DateFormat.DEFAULT, Locale.CHINA);  
            value = "‘" + formatter.format(new Date()) + "‘";  
        } else {  
            if (obj != null) {  
                value = obj.toString();  
            } else {  
                value = "";  
            }  
   
        }  
        return value;  
    }  
   
    public static String showSql(Configuration configuration, BoundSql boundSql) {  
        Object parameterObject = boundSql.getParameterObject();  
        List<ParameterMapping> parameterMappings = boundSql.getParameterMappings();  
        String sql = boundSql.getSql().replaceAll("[\\s]+", " ");  
        if (parameterMappings.size() > 0 && parameterObject != null) {  
            TypeHandlerRegistry typeHandlerRegistry = configuration.getTypeHandlerRegistry();  
            if (typeHandlerRegistry.hasTypeHandler(parameterObject.getClass())) {  
                sql = sql.replaceFirst("\\?", getParameterValue(parameterObject));  
   
            } else {  
                MetaObject metaObject = configuration.newMetaObject(parameterObject);  
                for (ParameterMapping parameterMapping : parameterMappings) {  
                    String propertyName = parameterMapping.getProperty();  
                    if (metaObject.hasGetter(propertyName)) {  
                        Object obj = metaObject.getValue(propertyName);  
                        sql = sql.replaceFirst("\\?", getParameterValue(obj));  
                    } else if (boundSql.hasAdditionalParameter(propertyName)) {  
                        Object obj = boundSql.getAdditionalParameter(propertyName);  
                        sql = sql.replaceFirst("\\?", getParameterValue(obj));  
                    }  
                }  
            }  
        }  
        return sql;  
    }  
   
    public Object plugin(Object target) {  
        return Plugin.wrap(target, this);  
    }  
   
    public void setProperties(Properties properties0) {  
        this.properties = properties0;  
    }  
}  

 

以上是关于mybatis xml怎么打印sql的主要内容,如果未能解决你的问题,请参考以下文章

MyBatis动态SQL

mybatis怎么配置log4j打印出sql语句

mybatis-plus 控制台打印sql,配置文件xml需注释掉,否则会冲突

log4j.xml打印mybatis sql

mybatis系统性详解(学习笔记)

学习MyBatis