iBATIS的調(diào)試

2018-12-09 11:01 更新

這是很容易調(diào)試程序與iBATIS的工作時(shí)。 iBATIS的有內(nèi)置的日志支持,并在按照以下順序記錄庫(kù)和搜索他們的作品。

  • Jakarta Commons的記錄(JCL)。
  • Log4J的
  • JDK日志

您可以使用上述任何圖書(shū)館與iBATIS的一起。

調(diào)試與Log4J的

假設(shè)你要使用log4j的日志記錄。在開(kāi)始之前,你需要交叉檢查以下幾點(diǎn) -

  • log4j的JAR文件(log4j- {}版本的.jar)應(yīng)在CLASSPATH中。
  • 你必須在CLASSPATH中提供log4j.properties。

以下是log4j.properties文件。請(qǐng)注意,某些行被注釋掉。如果你需要更多的調(diào)試信息,你可以取消它們。

# 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

你可以找到阿帕奇網(wǎng)站Log4j提供完整的文檔- log4j文檔 。

iBATIS的調(diào)試示例

下面的Java類是一個(gè)非常簡(jiǎn)單的例子,初始化,然后使用Java應(yīng)用程序Log4J日志庫(kù)。我們將使用其中位于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 ");
   }
}

編譯和運(yùn)行

首先,確保你已經(jīng)設(shè)置PATH和CLASSPATH在進(jìn)行適當(dāng)?shù)木幾g和執(zhí)行之前。

  • 創(chuàng)建Employee.xml如上所示。
  • 創(chuàng)建Employee.java如上圖所示,并對(duì)其進(jìn)行編譯。
  • 創(chuàng)建IbatisUpdate.java如上圖所示,并對(duì)其進(jìn)行編譯。
  • 如上圖所示創(chuàng)建log4j.properties。
  • 執(zhí)行IbatisUpdate二進(jìn)制運(yùn)行程序。

你會(huì)得到以下結(jié)果。 A記錄將在EMPLOYEE表進(jìn)行更新和后,同樣會(huì)記錄從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

調(diào)試方法

在上面的例子中,我們只用info()方法,但是你可以使用任何下列方法根據(jù)您的要求-

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);

以上內(nèi)容是否對(duì)您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)