MyBatis知多少(26)調試

這是很容易,同時與iBATIS的工做程序進行調試。 iBATIS有內置的日誌支持,並適用於下列日誌庫,並在這個順序搜索他們。html

  • Jakarta Commons日誌記錄(JCL)。java

  • Log4Jsql

  • JDK 日誌數據庫

能夠使用任何上面列出的庫在iBATIS。apache

調試和Log4J:

假設你要使用Log4J,這是最好用的日誌記錄。繼續操做以前,須要交叉檢查如下幾點:app

  • Log4J JAR 文件 (log4j-{version}.jar) 應在CLASSPATH中。網站

  • 必須在CLASSPATH中提供log4j.properties。ui

下面是一個log4j.properties文件。請注意,某些行被註釋掉了。你能夠取消他們,若是你須要額外的調試信息。spa

# 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 文檔.debug

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

系列文章:

MyBatis知多少(1)

MyBatis知多少(2)

MyBatis知多少(3)

MyBatis知多少(4)MyBatis的優點

MyBatis知多少(5)業務對象模型

MyBatis知多少(6)表現層與業務邏輯層

MyBatis知多少(7)持久層

MyBatis知多少(8)關係型數據庫

MyBatis知多少(9)不一樣類型的數據庫

MyBatis知多少(10)應用程序數據庫

MyBatis知多少(11)企業數據庫

MyBatis知多少(12)私有數據庫

MyBatis知多少(13)MyBatis如何解決數據庫的常見問題

MyBatis知多少(14)分散的數據庫系統

MyBatis知多少(15)數據模型

MyBatis知多少(16)MyBatis映射

MyBatis知多少(17)MyBatis和JDBC

MyBatis知多少(18)MyBatis系統

MyBatis知多少(19)MyBatis操做

MyBatis知多少(20)MyBatis讀取操做

MyBatis知多少(21)更新操做

MyBatis知多少(22)MyBatis刪除操做

MyBatis知多少(23)MyBatis結果映射

MyBatis知多少(24)存儲過程

MyBatis知多少(25)動態SQL

相關文章
相關標籤/搜索