Отладить вашу программу легко, работая с 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 () , однако вы можете использовать любой из следующих методов в соответствии с вашими требованиями: