我的编程空间,编程开发者的网络收藏夹
学习永远不晚

springmvc中怎么利用Mybatis输出Log4j日志

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

springmvc中怎么利用Mybatis输出Log4j日志

springmvc中怎么利用Mybatis输出Log4j日志,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

第一种情况

下面文档描述的mybatis本身内置很多种日志框架使用,所以如果我们要用具体哪个日志框架,就需要进行相应mybatis配置,或者就是按照mybatis本身规则运行。

问题在这里文档:http://mybatis.github.io/mybatis-3/zh/logging.html

配置方式:新增文件,有就直接添加mybatis-config.xml

<?xml version="1.0" encoding="UTF-8" ?>  <!DOCTYPE configuration    PUBLIC "-//mybatis.org//DTD Config 3.0//EN"    "http://mybatis.org/dtd/mybatis-3-config.dtd"><configuration><settings>          <setting name="logImpl" value="LOG4J"/>      </settings>  </configuration>

再把这个文件添加到:

<!--(主库)整合相应的MyBatis持久层相应的插件并注册相应的MyBatis模板 (dataSource1 主库数据源)-->    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">      <property name="dataSource" ref="dynamicDataSource" />      <property name="configLocation" value="classpath:mybatis-config.xml"></property><!-- 配置mybatis的日志记录 -->        <property name="mapperLocations" value="classpath*:com/belle/finance**/daomapper/mapper/*Mapper.xml"/>    </bean>

这样就配置好了,使用log4j进行日志记录不会运行mybatis自身规则。

第二种情况

就是log4j的日志级别使用错误,导致mybatis信息打印不出来;

日志级别

每个Logger都被了一个日志级别(log level),用来控制日志信息的输出。日志级别从高到低分为:

A:off 最高等级,用于关闭所有日志记录。

B:fatal 指出每个严重的错误事件将会导致应用程序的退出。

C:error 指出虽然发生错误事件,但仍然不影响系统的继续运行。

D:warm 表明会出现潜在的错误情形。

E:info 一般和在粗粒度级别上,强调应用程序的运行全程。

F:debug 一般用于细粒度级别上,对调试应用程序非常有帮助。

G:all 最低等级,用于打开所有日志记录。

上面这些级别是定义在org.apache.log4j.Level类中。Log4j只建议使用4个级别,优先级从高到低分别是error,warn,info和debug。通过使用日志级别,可以控制应用程序中相应级别日志信息的输出。例如,如果使用b了info级别,则应用程序中所有低于info级别的日志信息(如debug)将不会被打印出来。

根据上面的log4j的说明,另外根据mybatis的细粒度得出,mybatis要把log4j的日志至少配置到DEBUG级别,才能显示出sql日志,如下:

log4j.logger.com.demo.user=DEBUG

Mybatis内置的日志工厂提供日志功能,具体的日志实现有以下几种工具:

  • SLF4J

  • Apache Commons Logging

  • Log4j 2

  • Log4j

  • JDK logging

具体选择哪个日志实现工具由MyBatis的内置日志工厂确定。它会使用最先找到的(按上文列举的顺序查找)。 如果一个都未找到,日志功能就会被禁用。

不少应用服务器的classpath中已经包含Commons Logging,如Tomcat和WebShpere, 所以MyBatis会把它作为具体的日志实现。记住这点非常重要。

这将意味着,在诸如 WebSphere的环境中——WebSphere提供了Commons Logging的私有实现,你的Log4J配置将被忽略。

这种做法不免让人悲催,MyBatis怎么能忽略你的配置呢?事实上,因Commons Logging已经存 在了,按照优先级顺序,Log4J自然就被忽略了!

不过,如果你的应用部署在一个包含Commons Logging的环境, 而你又想用其他的日志框架,你可以通过在MyBatis的配置文件mybatis-config.xml里面添加一项setting(配置)来选择一个不同的日志实现。

Log4j实现日志输出功能

一、为什么要配置mybtis的logger?

mybatis自己设计以及实现了org.apache.ibatis.logging.Log接口。

Mybatis为了避免对第三方的日志包存在强依赖,内部的Log采用了代理模式。通过配置的方式,代理真实的日志对象. 如果没有配置log,mybatis会按照以下顺序尝试加载日志输出类:

  1. SLF4J

  2. Apache Commons Logging

  3. Log4j 2

  4. Log4j

  5. JDK logging

  6. no logging(没有日志)

二、如何开启日志输出?

1 下载log4j的jar包并导入到build path下

springmvc中怎么利用Mybatis输出Log4j日志

2 开启日志输出的配置

在config.xml文件中的settings元素中配置日志实现类。

<settings><setting name="logImpl" value="LOG4J"/></settings>

3 编写一个文件:log4j.properties放在类路径下面

第一行表示日志输出的级别的debug级别,Console表示输出位置是控制台(可以输出到文件或数据库,可以是发邮件)。

log4j.rootLogger=DEBUG,Consolelog4j.appender.Console=org.apache.log4j.ConsoleAppenderlog4j.appender.Console.layout=org.apache.log4j.PatternLayoutlog4j.appender.Console.layout.ConversionPattern=%d [%t] %-5p [%c] - %m%n

4 log4j的日志输出的级别:

  1. DEBUG < INFO < WARN < <ERROR < FATAL

  2. DEBUG :流经系统的详细信息。最低级别的日志输出,一般用于开发阶段的调试。

  3. INFO :一般消息输出(启动、关闭)

  4. WARN :警告输出

  5. ERROR :错误输出

  6. FATAL :导致应用程序提前终止的严重错误。一般这些信息将立即呈现在状态控制台上。

查看日志输出

debug基本的输出可以清楚地看到连接数据库的详细信息。

springmvc中怎么利用Mybatis输出Log4j日志

看完上述内容,你们掌握springmvc中怎么利用Mybatis输出Log4j日志的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注编程网行业资讯频道,感谢各位的阅读!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

springmvc中怎么利用Mybatis输出Log4j日志

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

springmvc中怎么利用Mybatis输出Log4j日志

springmvc中怎么利用Mybatis输出Log4j日志,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。第一种情况下面文档描述的mybatis本身内置很多种日志框架使用,所以
2023-06-20

MyBatis中怎么控制SQL日志输出

在 MyBatis 中,可以通过配置文件来控制 SQL 日志的输出。具体步骤如下:在 MyBatis 的配置文件中,可以使用 标签来配置相关的参数。例如,可以设置 logImpl 参数来指定日志输出的实现类。常用的参数
MyBatis中怎么控制SQL日志输出
2024-04-08

Java中Log4j日志怎么用

这篇文章给大家分享的是有关Java中Log4j日志怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。为什么要用日志?我们知道,程序在运行过程中会产生很多很多信息,比如在几点几分的时候运行了,运行的结果是怎么样的
2023-06-29

怎么在Python中使用handler方法输出日志

今天就跟大家聊聊有关怎么在Python中使用handler方法输出日志,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。Python主要用来做什么Python主要应用于:1、Web开发;
2023-06-14

使用shell脚本怎么按当前日期输出日志

这期内容当中小编将会给大家带来有关使用shell脚本怎么按当前日期输出日志,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。shell脚本基本技能是设置变量,输出信息。如下:sh脚本输出到控制台将以上脚本保存
2023-06-09

怎么在python中利用 loguru记录日志

本篇文章为大家展示了怎么在python中利用 loguru记录日志,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。python有哪些常用库python常用的库:1.requesuts;2.scrapy
2023-06-14

怎么在python中利用traceback输出异常

这篇文章给大家介绍怎么在python中利用traceback输出异常,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。python的数据类型有哪些?python的数据类型:1. 数字类型,包括int(整型)、long(长整
2023-06-14

MyBatis中怎么禁用特定SQL语句的日志

在MyBatis中,可以通过在配置文件中设置相应的日志级别来禁用特定SQL语句的日志输出。在mybatis-config.xml文件中,可以配置元素来设置MyBatis的全局属性,其中包括logImpl属性用于指定日志
MyBatis中怎么禁用特定SQL语句的日志
2024-04-28

怎么在python中利用for循环实现内输出和外输出

这期内容当中小编将会给大家带来有关怎么在python中利用for循环实现内输出和外输出,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。Python主要用来做什么Python主要应用于:1、Web开发;2、数
2023-06-14

怎么在python中利用loguru对日志进行操作

本篇文章为大家展示了怎么在python中利用loguru对日志进行操作,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。python可以做什么Python是一种编程语言,内置了许多有效的工具,Pytho
2023-06-14

PHP 中怎么利用error_log()函数处理错误日志

PHP 中怎么利用error_log()函数处理错误日志,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。PHP error_log()函数主要是用来写错误日志的函数,我们在多
2023-06-17

Python中怎么利用logging模块记录程序日志

本篇文章给大家分享的是有关Python中怎么利用logging模块记录程序日志,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。首先来看logging简单的使用方法。这一看到此图中
2023-06-04

怎么在python中利用print函数格式化输出

今天就跟大家聊聊有关怎么在python中利用print函数格式化输出,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。python主要应用领域有哪些1、云计算,典型应用OpenStack
2023-06-14

linux中怎么利用find命令实现日志定期迁移

linux中怎么利用find命令实现日志定期迁移,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。一,find命令格式find pathname --optio
2023-06-13

怎么在shell中利用递归输出文件名和目录名

这期内容当中小编将会给大家带来有关怎么在shell中利用递归输出文件名和目录名,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。shell脚本实现function echo_name(){ for file
2023-06-09

怎么在linux中利用shell脚本输出带颜色的字体

今天就跟大家聊聊有关怎么在linux中利用shell脚本输出带颜色的字体,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。输出特效格式控制:\033[0m 关闭所有属性 \033[1
2023-06-09

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录