這是很容易,同時與iBATIS的工做程序進行調試。 iBATIS有內置的日誌支持,並適用於下列日誌庫,並在這個順序搜索他們。html
Jakarta Commons日誌記錄(JCL)。java
Log4Jsql
JDK 日誌數據庫
能夠使用任何上面列出的庫在iBATIS。apache
假設你要使用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
下面的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);
系列文章: