iBATIS调试

   

这是很容易,同时与iBATIS的工作程序进行调试。 iBATIS有内置的日志支持,并适用于下列日志库,并在这个顺序搜索他们。

  • Jakarta Commons日志记录(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

可以找到完整的Log4J文档,从Apaches 网站: 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二进制文件来运行程序。

会得到下面的结果,并记录在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);
   
正文到此结束
Loading...