赞
踩
在使用mybatis进行开发的时候,由于可以动态拼接sql,这样大大方便了我们。但是也有一定的问题,当我们动态sql拼接的块很多的时候,我们要想从*mapper.xml中直接找出完整的sql就会非常的难,这个时候经常会需要把组合之后的完整SQL语句打印出来,对调试非常有帮助的。
下面介绍几种控制台打印SQL语句的方式,并配上相应示例:
在Mybatis的配置文件中配置log4j或其他日志框架,然后配置输出级别、输出格式等。示例如下:
- <configuration>
- <!-- 定义日志格式 -->
- <layout class="org.apache.log4j.PatternLayout">
- <param name="ConversionPattern" value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%-5p] %c{1}:%L - %m%n"/>
- </layout>
-
- <!-- 定义输出级别 -->
- <root>
- <priority value="DEBUG"/>
- <appender-ref ref="STDOUT"/>
- </root>
- </configuration>
实现Interceptor接口,在intercept方法中打印SQL语句。示例如下:
- public class SqlLogInterceptor implements Interceptor {
- @Override
- public Object intercept(Invocation invocation) throws Throwable {
- Object[] args = invocation.getArgs();
-
- if (args != null && args.length > 1) {
- MappedStatement mappedStatement = (MappedStatement) args[0];
- Object parameter = args[1];
- BoundSql boundSql = mappedStatement.getBoundSql(parameter);
-
- String sql = boundSql.getSql();
- System.out.println("SQL语句:" + sql);
- }
-
- return invocation.proceed();
- }
- }
在Mybatis的配置文件中添加debug标签,设置为true即可打印SQL语句和参数信息,同时也会输出相关的结果集信息。示例如下:
- <configuration>
- <!-- 将debug设置为true -->
- <settings>
- <setting name="debug" value="true"/>
- </settings>
- </configuration>
在Mybatis的配置文件中配置parameterMap标签,配合loggingLevel和cacheEnabled属性即可打印相关日志信息,示例如下:
- <configuration>
- <cacheEnabled>true</cacheEnabled>
- <parameterMap id="ParamMap" type="map">
- <parameter property="id" jdbcType="INTEGER"/>
- </parameterMap>
-
- <!-- 设置loggingLevel为TRACE -->
- <settings>
- <setting name="logImpl" value="LOG4J"/>
- <setting name="jdbcTypeForNull" value="NULL"/>
- <setting name="cacheEnabled" value="true"/>
- <setting name="loggingLevel" value="TRACE"/>
- </settings>
- </configuration>
以上就是几种控制台打印SQL语句的方式及相应示例。选择适合自己的方式,会帮助我们更好地进行数据库调试和优化。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。