在线观看不卡亚洲电影_亚洲妓女99综合网_91青青青亚洲娱乐在线观看_日韩无码高清综合久久

鍍金池/ 教程/ Java/ iBATIS調(diào)試
iBATIS和Hibernate區(qū)別
iBATIS刪除操作
iBATIS存儲(chǔ)過程
iBATIS讀取操作
iBATOR介紹,什么是iBATOR?
iBATIS創(chuàng)建操作
ibatis
iBATIS調(diào)試
iBATIS配置環(huán)境
iBATIS結(jié)果映射
iBATIS動(dòng)態(tài)SQL
iBATIS介紹,iBATIS是什么?
iBATIS更新操作

iBATIS調(diào)試

這是很容易,同時(shí)與iBATIS的工作程序進(jìn)行調(diào)試。 iBATIS有內(nèi)置的日志支持,并適用于下列日志庫,并在這個(gè)順序搜索他們。

  • Jakarta Commons日志記錄(JCL)。

  • Log4J

  • JDK 日志

可以使用任何上面列出的庫在iBATIS。

調(diào)試和Log4J:

假設(shè)你要使用Log4J,這是最好用的日志記錄。繼續(xù)操作之前,需要交叉檢查以下幾點(diǎn):

  • Log4J JAR 文件 (log4j-{version}.jar) 應(yīng)在CLASSPATH中。

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

下面是一個(gè)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

可以找到完整的Log4J文檔,從Apaches 網(wǎng)站: Log4J 文檔.

iBATIS 調(diào)試?yán)樱?/h2>

下面的Java類是一個(gè)非常簡單的例子,初始化,然后使用Java應(yīng)用程序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 ");

  }
}

編譯和運(yùn)行:

下面是步驟來編譯并運(yùn)行上述軟件。請(qǐng)確保您已在進(jìn)行的編譯和執(zhí)行之前,適當(dāng)?shù)卦O(shè)置PATH和CLASSPATH。

  • 創(chuàng)建Employee.xml如上所示。

  • 創(chuàng)建Employee.java如上圖所示,并編譯它。

  • 創(chuàng)建IbatisUpdate.java如上圖所示,并編譯它。

  • 創(chuàng)建log4j.properties文件,如上圖所示。

  • 執(zhí)行IbatisUpdate二進(jìn)制文件來運(yùn)行程序。

會(huì)得到下面的結(jié)果,并記錄在EMPLOYEE表進(jìn)行更新, 然后相同的記錄將被從EMPLOYEE表中讀出。

DEBUG