- iBATIS 教程
- iBATIS - 首页
- iBATIS - 概述
- iBATIS - 环境配置
- iBATIS - 创建操作
- iBATIS - 读取操作
- iBATIS - 更新操作
- iBATIS - 删除操作
- iBATIS - 结果映射
- iBATIS - 存储过程
- iBATIS - 动态SQL
- iBATIS - 调试
- iBATIS - Hibernate对比
- iBATOR - 简介
- iBATIS 有用资源
- iBATIS - 快速指南
- iBATIS - 有用资源
- iBATIS - 讨论
iBATIS - 调试
使用 iBATIS 时,调试程序很容易。iBATIS 内置了日志支持,并按以下顺序搜索以下日志库。
- Jakarta Commons Logging (JCL)。
- Log4J
- JDK 日志记录
您可以将上述任何库与 iBATIS 一起使用。
使用 Log4J 进行调试
假设您将使用 Log4J 进行日志记录。在继续之前,您需要交叉检查以下几点:
- Log4J JAR 文件 (log4j-{version}.jar) 应该在 CLASSPATH 中。
- 您的 CLASSPATH 中有 log4j.properties 文件。
以下是 log4j.properties 文件。请注意,某些行已注释掉。如果需要其他调试信息,可以取消注释它们。
# Global logging configuration log4j.rootLogger = ERROR, stdout log4j.logger.com.ibatis = DEBUG # shows SQL of prepared statements #log4j.logger.java.sql.Connection = DEBUG # shows parameters inserted into prepared statements #log4j.logger.java.sql.PreparedStatement = DEBUG # shows query results #log4j.logger.java.sql.ResultSet = DEBUG #log4j.logger.java.sql.Statement = DEBUG # Console output log4j.appender.stdout = org.apache.log4j.ConsoleAppender log4j.appender.stdout.layout = org.apache.log4j.PatternLayout log4j.appender.stdout.layout.ConversionPattern = %5p [%t] − %m%n
您可以从 Apache 网站找到 Log4J 的完整文档:Log4J 文档。
iBATIS 调试示例
以下 Java 类是一个非常简单的示例,它初始化然后使用 Log4J 日志库用于 Java 应用程序。我们将使用上面提到的位于 CLASSPATH 中的属性文件。
import org.apache.log4j.Logger; import com.ibatis.common.resources.Resources; import com.ibatis.sqlmap.client.SqlMapClient; import com.ibatis.sqlmap.client.SqlMapClientBuilder; import java.io.*; import java.sql.SQLException; import java.util.*; public class IbatisUpdate{ static Logger log = Logger.getLogger(IbatisUpdate.class.getName()); public static void main(String[] args) throws IOException,SQLException{ Reader rd = Resources.getResourceAsReader("SqlMapConfig.xml"); SqlMapClient smc = SqlMapClientBuilder.buildSqlMapClient(rd); /* This would insert one record in Employee table. */ log.info("Going to update record....."); Employee rec = new Employee(); rec.setId(1); rec.setFirstName( "Roma"); smc.update("Employee.update", rec ); log.info("Record updated Successfully "); log.debug("Going to read records....."); List <Employee> ems = (List<Employee>) smc.queryForList("Employee.getAll", null); Employee em = null; for (Employee e : ems) { System.out.print(" " + e.getId()); System.out.print(" " + e.getFirstName()); System.out.print(" " + e.getLastName()); System.out.print(" " + e.getSalary()); em = e; System.out.println(""); } log.debug("Records Read Successfully "); } }
编译和运行
首先,确保在进行编译和执行之前已正确设置 PATH 和 CLASSPATH。
- 创建如上所示的 Employee.xml。
- 创建如上所示的 Employee.java 并编译它。
- 创建如上所示的 IbatisUpdate.java 并编译它。
- 创建如上所示的 log4j.properties。
- 执行 IbatisUpdate 二进制文件以运行程序。
您将获得以下结果。一条记录将被更新到 EMPLOYEE 表中,稍后将从 EMPLOYEE 表中读取相同的记录。
DEBUG [main] - Created connection 28405330. DEBUG [main] - Returned connection 28405330 to pool. DEBUG [main] - Checked out connection 28405330 from pool. DEBUG [main] - Returned connection 28405330 to pool. 1 Roma Ali 5000 2 Zara Ali 5000 3 Zara Ali 5000
调试方法
在上面的示例中,我们只使用了 `info()` 方法,但是您可以根据需要使用以下任何方法:
public void trace(Object message); public void debug(Object message); public void info(Object message); public void warn(Object message); public void error(Object message); public void fatal(Object message);
广告