Учебники

iBATIS — отладка

Отладить вашу программу легко, работая с iBATIS. iBATIS имеет встроенную поддержку ведения журналов и работает со следующими библиотеками журналов и ищет их в этом порядке.

  • Jakarta Commons Logging (JCL).
  • Log4J
  • JDK логирование

Вы можете использовать любую из перечисленных выше библиотек вместе с iBATIS.

Отладка с помощью Log4J

Предполагая, что вы собираетесь использовать Log4J для регистрации. Прежде чем продолжить, вам необходимо перепроверить следующие пункты —

  • Файл JAR Log4J (log4j- {версия} .jar) должен находиться в CLASSPATH.
  • У вас есть log4j.properties, доступные в CLASSPATH.

Ниже приведен файл 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 с сайта ApacheДокументация Log4J .

Пример отладки iBATIS

Следующий класс Java является очень простым примером, который инициализирует, а затем использует библиотеку журналов Log4J для приложений Java. Мы будем использовать вышеупомянутый файл свойств, который находится в 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 () , однако вы можете использовать любой из следующих методов в соответствии с вашими требованиями: