iBATIS的调试
2018-12-09 11:01 更新
这是很容易调试程序与iBATIS的工作时。 iBATIS的有内置的日志支持,并在按照以下顺序记录库和搜索他们的作品。
- Jakarta Commons的记录(JCL)。
- Log4J的
- JDK日志
您可以使用上述任何图书馆与iBATIS的一起。
调试与Log4J的
假设你要使用log4j的日志记录。在开始之前,你需要交叉检查以下几点 -
- log4j的JAR文件(log4j- {}版本的.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
你可以找到阿帕奇网站Log4j提供完整的文档- log4j文档 。
iBATIS的调试示例
下面的Java类是一个非常简单的例子,初始化,然后使用Java应用程序Log4J日志库。我们将使用其中位于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二进制运行程序。
你会得到以下结果。 A记录将在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);
以上内容是否对您有帮助:
更多建议: