• mybatisplus开启sql打印的三种方式


     1、在application.yml文件中添加mybatisplus的配置文件

            使用mybatisplus自带的log-impl配置,可以在控制台打印出sql语句、执行结果的数据集、数据结果条数等详细信息,这种方法适合再调试的时候使用,因为这个展示的信息详细,更便于调试,查找问题进行优化。缺点就是如果执行的sql语句过多,则输出的日志就会很多,

    1. mybatis-plus:
    2. configuration:
    3. log-impl: org.apache.ibatis.logging.stdout.StdOutImpl #开启sql日志

    96ebdf599bbb497bb214202d3aa500ea.png

    2、在application.yml文件中使用log4j日志框架配置

    使用这个方法可以再控制台或者日志文件中打印sql语句,这种方法比较适合再生产环境种使用,可以避免输出过多的无用信息,也可以使用日志级别来控制是否打印sql语句。

    //com.example.classroomrealtimefeedback.mapper是你mapper层的包名

    1. logging:
    2. level:
    3. com.example.classroomrealtimefeedback.mapper: debug

    f3c69d5cb1d54370b7feaf5b83570f7a.png

    3 、使用P6spy插件

            可以再控制台中打印出sql语句,并且再控制台中将输出的sql中的?部分替换位真实运行的值,这种方法适合需要复制sql语句到数据库工具中直接执行的场景,也可以通过spyproperties文件来配置是否开启慢sql记录、慢sql记录标准的参数。该插件有性能损耗,不建议生产环境使用

    引用依赖: 

    1. <dependency>
    2. <groupId>p6spy</groupId>
    3. <artifactId>p6spy</artifactId>
    4. <version>3.9.1</version>
    5. </dependency>

    修改.yml配置文件:

    这里的配置是将mysql数据库和这个插件的配置合一起了。

    1. spring:
    2. datasource:
    3. driver-class-name: com.p6spy.engine.spy.P6SpyDriver
    4. url: jdbc:p6spy:mysql://127.0.0.1:3306/qcby?rewriteBatchedStatements=true&useUnicode=true&characterEncoding=utf-8
    5. #mysql为数据库类型,后面为数据库连接地址,

    配置spy.properties文件:

    1. modulelist=com.baomidou.mybatisplus.extension.p6spy.MybatisPlusLogFactory,com.p6spy.engine.outage.P6OutageFactory
    2. logMessageFormat=com.baomidou.mybatisplus.extension.p6spy.P6SpyLogger
    3. appender=com.baomidou.mybatisplus.extension.p6spy.StdoutLogger
    4. deregisterdrivers=true
    5. useprefix=true
    6. dateformat=yyyy-MM-dd HH:mm:ss
    7. # 实际驱动可多个
    8. #driverlist=org.h2.Driver
    9. # 是否开启慢SQL记录
    10. outagedetection=true
    11. # 慢SQL记录标准 1
    12. outagedetectioninterval=1

     输出结果:63b6a6b93fd44d21a7fa72135932a5fe.png

    可能出现的问题: 

    • 打印出sql为null,在excludecategories增加commit
    • 批量操作不打印sql,去除excludecategories中的batch

  • 相关阅读:
    js中的call() apply() bind()的用法
    shell_57.Linux创建自己的重定向
    Kubernetes 理解kubectl/调试
    【数据结构】深入了解队列
    MySql分区介绍和Range案例
    LeetCode每日一题(Palindrome Partitioning III)
    【kafka专栏】生产者客户端自定义序列化器
    程序验证之Dafny--证明霍尔逻辑的半自动化利器
    网络安全(黑客)自学
    技术人的面试求职套路
  • 原文地址:https://blog.csdn.net/qq_64680177/article/details/133944211