MyBatis Log 插件无法显示SQL语句的原因

MyBatis Log 插件无法显示SQL语句的原因_第1张图片

MyBatis Log是IDEA一款下载量非常高的插件,该插件可以对控制台打印的日志进行解析,然后将对应的SQL语句整理并拼接好对应的参数,非常方便。有时插件却无法打印SQL,总的来说,有如下三种原因:

1. 项目的日志等级过高,修改日志等级为 DEBUG 或 INFO

## log4j.properties 文件
log4j.rootLogger = DEBUG,stdout,D
 
或者
 
## application-dev.yml 文件
loggig:
    level:
        root: DEBUG

2. mybatis配置中没有设置将sql日志输出到控制台 主要原因

## mybatis-config.xml 文件
<configuration>
    <settings>
        <setting name="logImpl" value="org.apache.ibatis.logging.stdout.StdOutImpl" />
    </settings>
</configuration>
 
或者
 
## application-dev.yml 文件
mybatis-plus:
  configuration:
      ## 日志
      log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

3. 控制台打印的日志格式不符合规范,插件无法解析

修改日志打印的格式即可,推荐格式如下:
## log4j.properties 文件
###控制台日志输出###
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target = System.out
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern = [%p] - [%t] - [%d{yyyy-MM-dd HH\:mm\:ss\:SSS}] - (%c{1}\:%L) - %m%n
 
或者
 
## application.yml 文件
# 日志设置配置
logging:
  pattern:
    console: '%X{RequestNo}-%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36}[%L] - %msg%n'

你可能感兴趣的:(mybatis,sql,数据库)