调试 debug
优质
小牛编辑
120浏览
2023-12-01
在使用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
您可以从Apaches站点 - 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 ");
}
}
编译和运行 (Compilation and Run)
首先,确保在继续编译和执行之前适当地设置了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);