码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • logback(三)mybatis-plus结合logback将sql语句输出到日志文件


    logback(一)理论概述
    logback(二)springboot配置日志文件格式、logback-spring配置文件详解
    logback(三)mybatis-plus结合logback将sql语句输出到日志文件

    建议看看前两篇文章

    1 yml配置mybatis-plus和logger

    logging:
      config: classpath:logback-spring.xml
    #  level:
    #    com.fox.test.mapper: debug
      file:
        path: /mnt/logs/fox/test
    
    mybatis-plus:
      mapper-locations: classpath*:mapper/*.xml
      type-aliases-package: com.fox.test.domain.entity
      configuration:
        log-impl: org.apache.ibatis.logging.slf4j.Slf4jImpl
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • type-aliases-package 你的entity,就是和数据库表一一对应的实体字段
    • log-impl 的值有以下两种
      org.apache.ibatis.logging.stdout.StdOutImpl代表在控制台打印sql
      org.apache.ibatis.logging.slf4j.Slf4jImpl代表在文件里面写入

    2 在logback.xml文件里面在配置一个当前系统包的日志输出级别

    <!-- debug及以上级别的信息【可以包括sql信息】输出到文件 TODO 不需要可以自行删除 -->
        <appender name="file_debug" class="ch.qos.logback.core.rolling.RollingFileAppender">
            <encoder>
                <pattern>${logPattern}</pattern>
            </encoder>
    
            <file>${logPath}/sys-debug.${hostname}.log</file>
            <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
                <fileNamePattern>${logPath}/sys-debug.%d{yyyy-MM-dd}.${hostname}.log</fileNamePattern>
                <maxHistory>7</maxHistory>
            </rollingPolicy>
        </appender>
    
        <!--将mybatis-plus的sql记录的日志文件 TODO name改成自己的项目的mapper包路径-->
        <logger name="com.fox.test.mapper" level="debug" />
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    logger标签等效于yml里面的logging.level,就是我上面注释掉的,只不过写的位置不一样,效果一样,最好不要同时写

    控制台输出,即便使用了Slf4jImpl,也可以在控制台输出(配置包路径的日志级别即可,不知道的看上一篇文章)
    在这里插入图片描述
    日志文件
    在这里插入图片描述

    Slf4jImpl类里面其实是ibatis(mybatis的前身,pluss是mybatis的升级版)和log4j(Logback继承了log4j)、log4j2、slf4j(这个是个独立的包)的结合体。前人栽树,后人乘凉。感谢各位计算机前辈们,我们直接使用即可

    在这里插入图片描述
    而StdOutImpl类里面直接使用System.out.println()输出的
    在这里插入图片描述

  • 相关阅读:
    在 CSS 中,怎样有效地优化样式表的加载性能,减少页面加载时间?
    矩阵的投影、线性拟合与最小二乘法
    【slam十四讲第二版】【课本例题代码向】【第十讲~后端2】
    使用MySQL,请用好 JSON 这张牌
    数字化转型的关键在于节省时间
    深度学习之基于Pytorch服装图像分类识别系统
    day5-selenium的高级和实战
    ShardingSphere-proxy-5.0.0容量范围分片的实现(五)
    【洛谷 P1182】数列分段 Section II 题解(二分答案+递归)
    Effective C++条款24:若所有参数皆需类型转换,请为此采用non-member函数
  • 原文地址:https://blog.csdn.net/lh155136/article/details/125616984
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号