我们在对数据库进行增删改查的时候,出现异常,需要排错,如果在控制台能输出对应的SQL,就有了更快的排错效率,在以往的开发中,遇到问题我们通常使用debug模式跟踪代码执行过程来进行排错,而Mybatis是基于接口,配置文件的源代码执行过程,所以必须选择使用日志工具来进行调试
- 1.常用的Mybatis日志实现工具
- 2.STDOUT_LOGGING(标准化日志输出)
- 3.Log4j
1.常用的Mybatis日志实现工具
- SLF4J
- Apache Commons Logging
- Log4j2
- Log4j
- JDK logging
具体选择哪个日志实现工具由Mybatis的内置工厂决定,它会使用最先找到的(按以上所列顺序进行查找),如果一个都没有找到,日志功能就会被禁用
2.STDOUT_LOGGING(标准化日志输出)- Mybatis默认的日志类型,不需要额外导包
- 在mybatis核心配置文件中配置
3.Log4j
- 是Apache的一个开源项目
- 可以控制日志信息输送的目的地:控制台,文本,GUI组件
- 也可以控制每一条日志的输出格式
- 通过定义每一条日志信息的级别,能够更加细致地控制日志的生成过程
- 可以通过配置文件来灵活的进行配置(不需要修改应用的代码)
使用步骤:
1)导入log4j的包
log4j log4j 1.2.17
2)编写配置文件log4j.properties
log4j.rootLogger=DEBUG,console,file
#控制台输出的相关设置
log4j.appender.console = org.apache.log4j.ConsoleAppender
log4j.appender.console.Target = System.out
log4j.appender.console.Threshold=DEBUG
log4j.appender.console.layout = org.apache.log4j.PatternLayout
#log4j.appender.console.layout.ConversionPattern=[%c]-%m%n
log4j.appender.console.layout.ConversionPattern=%5p [%t] - %m%n
#文件输出的相关设置
log4j.appender.file = org.apache.log4j.RollingFileAppender
log4j.appender.file.File=./log/rzk.log
log4j.appender.file.MaxFileSize=10mb
log4j.appender.file.Threshold=DEBUG
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=[%p][%d{yy-MM-dd}][%c]%m%n
#日志输出级别
log4j.logger.org.mybatis=DEBUG
log4j.logger.java.sql=DEBUG
log4j.logger.java.sql.Statement=DEBUG
log4j.logger.java.sql.ResultSet=DEBUG
log4j.logger.java.sql.PreparedStatement=DEBUG
3)setting设置日志实现
4)在程序中使用Log4j进行输出
public class UserDaoTest {
private static Logger logger = Logger.getLogger(UserDaoTest.class);
@Test
public void testLog4j(){
// System.out.println("This is println message.");
// 记录debug级别的信息
logger.debug("This is debug message.");
// 记录info级别的信息
logger.info("This is info message.");
// 记录error级别的信息
logger.error("This is error message.");
}
}



