sql性能分析打印


ofa通过集成p6spy,可以将sql执行时间和实际执行的sql打印到控制台,方便分析sql性能和调试,生产环境不建议使用,会损耗性能。

修改数据库配置

 datasource:
    druid:
      url: jdbc:p6spy:mysql://ip:port/db?useUnicode=true&characterEncoding=utf-8&serverTimezone=GMT%2B8
      username: root
      password:
      driver-class-name: com.p6spy.engine.spy.P6SpyDriver

将driver-class-name修改成com.p6spy.engine.spy.P6SpyDriver,url链接中间需要加上p6spy

添加配置文件spy.properties

modulelist=com.baomidou.mybatisplus.extension.p6spy.MybatisPlusLogFactory,com.p6spy.engine.outage.P6OutageFactory
# 自定义日志打印
logMessageFormat=com.baomidou.mybatisplus.extension.p6spy.P6SpyLogger
#日志输出到控制台
appender=com.baomidou.mybatisplus.extension.p6spy.StdoutLogger
# 使用日志系统记录 sql
#appender=com.p6spy.engine.spy.appender.Slf4JLogger
# 设置 p6spy driver 代理
deregisterdrivers=false
# 取消JDBC URL前缀
useprefix=true
# 配置记录 Log 例外,可去掉的结果集有error,info,batch,debug,statement,commit,rollback,result,resultset.
excludecategories=info,debug,result,commit,resultset
# 日期格式
dateformat=yyyy-MM-dd HH:mm:ss
# 实际驱动可多个
driverlist=com.mysql.cj.jdbc.Driver
# 是否开启慢SQL记录
outagedetection=true
# 慢SQL记录标准 2 秒
outagedetectioninterval=2

执行效果

Consume Time:12 ms 2020-02-25 14:47:37
 Execute SQL:SELECT id,permission,perm_name,menu_id FROM ofa_permission