这是很容易,同时与iBATIS的工作程序进行调试。 iBATIS有内置的日志支持,并适用于下列日志库,并在这个顺序搜索他们。

  • Jakarta Commons日志记录(JCL)。

  • Log4J

  • JDK 日志

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

调试和Log4J:

假设你要使用Log4J,这是最好用的日志记录。继续操作之前,需要交叉检查以下几点:

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

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

下面是一个log4j.properties文件。请注意,某些行被注释掉了。你可以取消他们,如果你需要额外的调试信息。

  1. # Global logging configuration
  2. log4j.rootLogger=ERROR, stdout
  3.  
  4. log4j.logger.com.ibatis=DEBUG
  5.  
  6. # shows SQL of prepared statements
  7. #log4j.logger.java.sql.Connection=DEBUG
  8.  
  9. # shows parameters inserted into prepared statements
  10. #log4j.logger.java.sql.PreparedStatement=DEBUG
  11.  
  12. # shows query results
  13. #log4j.logger.java.sql.ResultSet=DEBUG
  14.  
  15. #log4j.logger.java.sql.Statement=DEBUG
  16.  
  17. # Console output
  18. log4j.appender.stdout=org.apache.log4j.ConsoleAppender
  19. log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
  20. log4j.appender.stdout.layout.ConversionPattern=%5p [%t] - %m%n

可以找到完整的Log4J文档,从Apaches 网站: Log4J 文档.

iBATIS 调试例子:

下面的Java类是一个非常简单的例子,初始化,然后使用Java应用程序Log4J的日志库。它位于CLASSPATH中上面提到的属性文件。

  1. import org.apache.log4j.Logger;
  2.  
  3. import com.ibatis.common.resources.Resources;
  4. import com.ibatis.sqlmap.client.SqlMapClient;
  5. import com.ibatis.sqlmap.client.SqlMapClientBuilder;
  6. import java.io.*;
  7. import java.sql.SQLException;
  8. import java.util.*;
  9.  
  10. public class IbatisUpdate{
  11. static Logger log = Logger.getLogger(
  12. IbatisUpdate.class.getName());
  13.  
  14. public static void main(String[] args)
  15. throws IOException,SQLException{
  16. Reader rd = Resources.getResourceAsReader("SqlMapConfig.xml");
  17. SqlMapClient smc = SqlMapClientBuilder.buildSqlMapClient(rd);
  18.  
  19. /* This would insert one record in Employee table. */
  20. log.info("Going to update record.....");
  21. Employee rec = new Employee();
  22. rec.setId(1);
  23. rec.setFirstName( "Roma");
  24. smc.update("Employee.update", rec );
  25. log.info("Record updated Successfully ");
  26.  
  27. log.debug("Going to read records.....");
  28. List <Employee> ems = (List<Employee>)
  29. smc.queryForList("Employee.getAll", null);
  30. Employee em = null;
  31. for (Employee e : ems) {
  32. System.out.print(" " + e.getId());
  33. System.out.print(" " + e.getFirstName());
  34. System.out.print(" " + e.getLastName());
  35. System.out.print(" " + e.getSalary());
  36. em = e;
  37. System.out.println("");
  38. }
  39.  
  40. log.debug("Records Read Successfully ");
  41.  
  42. }
  43. }

编译和运行:

下面是步骤来编译并运行上述软件。请确保您已在进行的编译和执行之前,适当地设置PATH和CLASSPATH。

  • 创建Employee.xml如上所示。

  • 创建Employee.java如上图所示,并编译它。

  • 创建IbatisUpdate.java如上图所示,并编译它。

  • 创建log4j.properties文件,如上图所示。

  • 执行IbatisUpdate二进制文件来运行程序。

会得到下面的结果,并记录在EMPLOYEE表进行更新, 然后相同的记录将被从EMPLOYEE表中读出。

 
  1. DEBUG [main] - Created connection 28405330.
  2. DEBUG [main] - Returned connection 28405330 to pool.
  3. DEBUG [main] - Checked out connection 28405330 from pool.
  4. DEBUG [main] - Returned connection 28405330 to pool.
  5. 1 Roma Ali 5000
  6. 2 Zara Ali 5000
  7. 3 Zara Ali 5000

调试方法:

在上面的例子中,我们只使用info()方法,但可以使用以下任何一种方法按你的需要:

  1. public void trace(Object message);
  2. public void debug(Object message);
  3. public void info(Object message);
  4. public void warn(Object message);
  5. public void error(Object message);
  6. 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

MyBatis知多少(26)调试的更多相关文章

  1. MyBatis知多少(26)MyBatis和Hibernate区别

    iBatis和Hibernate之间有着较大的差异,但两者解决方案很好,因为他们有特定的领域.我个人建议使用MyBatis的,如果: 你想创建自己的SQL,并愿意维持他们. 你的环境是由关系数据模型驱 ...

  2. MyBatis知多少(25)动态SQL

    使用动态查询是MyBatis一个非常强大的功能.有时你已经改变WHERE子句条件的基础上你的参数对象的状态.在这种情况下的MyBatis提供了一组可以映射语句中使用,以提高SQL语句的重用性和灵活性的 ...

  3. MyBatis知多少(24)存储过程

    使用MyBatis配置来调用存储过程.为了理解这一章,首先需要了解我们是如何在MySQL中创建一个存储过程. 在继续对本节学习之前,可以自行学习MySQL存储过程. 我们已经在MySQL下有EMPLO ...

  4. MyBatis知多少(23)MyBatis结果映射

    resultMap的元素是在MyBatis的最重要和最强大的元素.您可以通过使用MyBatis的结果映射减少高达90%的JDBC编码,在某些情况下,可以让你做JDBC不支持的事情. ResultMap ...

  5. MyBatis知多少(22)MyBatis删除操作

    本节从表中使用MyBatis删除记录. 我们已经在MySQL下有EMPLOYEE表: CREATE TABLE EMPLOYEE ( id INT NOT NULL auto_increment, f ...

  6. MyBatis知多少(21)更新操作

    上一章展示了如何使用MyBatis对表进行读取操作.本章将告诉你如何在一个表中使用MyBatis更新记录. 我们已经在MySQL下有EMPLOYEE表: CREATE TABLE EMPLOYEE ( ...

  7. MyBatis知多少(20)MyBatis读取操作

    上篇展示了如何使用MyBatis执行创建操作表.本章将告诉你如何使用MyBatis来读取表. 我们已经在MySQL下有EMPLOYEE表: CREATE TABLE EMPLOYEE ( id INT ...

  8. MyBatis知多少(19)MyBatis操作

    若要使用iBATIS执行的任何CRUD(创建,写入,更新和删除)操作,需要创建一个的POJO(普通Java对象)类对应的表.本课程介绍的对象,将“模式”的数据库表中的行. POJO类必须实现所有执行所 ...

  9. MyBatis知多少(18)MyBatis系统

    小型.简单系统 小型应用程序通常只涉及单个数据库,只有一些相当简单的用户界面和领域模型.它的业务逻辑非常简单,甚至对一些简单的CRUD (Create, Read, Update, Delete:增删 ...

随机推荐

  1. SHINY-SERVER R(sparkR)语言web解决方案 架设shiny服务器

    1. shiny server简介 shiny-server是一种可用把R 语言以web形式展示的服务,其实RStudio公司自己构建了R Shiny Application运行的平台(http:// ...

  2. iOS之富文本

    之前做项目时遇到一个问题: 使用UITextView显示一段电影的简介,由于字数比较多,所以字体设置的很小,行间距和段间距也很小,一大段文字挤在一起看起来很别扭,想要把行间距调大,结果在XCode中查 ...

  3. Java Socket网络编程常见异常(转)

    1.java.net.SocketTimeoutException 这个异常比较常见,socket超时.一般有2个地方会抛出这个,一个是connect的时候,这个超时参数由connect(Socket ...

  4. SDWebImage ReadMe.md文档简单说明

    SDWebImage ReadMe.md 文档 附:SDWebImage框架github下载地址:https://github.com/rs/SDWebImage 注1:该文章简单翻译了SDWebIm ...

  5. android: 使用 AsyncTask

    9.2.4    使用 AsyncTask 不过为了更加方便我们在子线程中对 UI 进行操作,Android 还提供了另外一些好用的工 具,AsyncTask 就是其中之一.借助 AsyncTask, ...

  6. NMAP 基础教程

    原文地址: http://drops.wooyun.org/tips/2002 0x00 nmap 介绍 Nmap  (网络映射器)是由 Gordon Lyon设计,用来探测计算机网络上的主机和服务的 ...

  7. eclipse 引用自己开发的模块

    这样就可以 生成的是LIB 工程需要设置“Is Library”

  8. Visual Studio 2013 无法正常打开项目文件

    提示:无法打开 vcxproj 因为此版本的应用程序不支持其项目类型 ,若要打开它 请使用支持此类型项目的版本. 检查  AppData\Roaming\Microsoft\VisualStudio\ ...

  9. Mac OS 中设置VPN(pptp连接方式)

    第一步:点击系统设置(如图) 第二步:点击网络,进入网络设置(如图) 第三步:点击+号-创建新服务,创建新的VPN网络连接(如图) 第四步:接口-中选-VPN, VPN类型-中选-PPTP,服务名称- ...

  10. [Android实例] 有关spinner 的item问题 谁能给解答下??

    [Android实例] 有关spinner 的item问题 (更多Android问题解决,Android开发讨论 请访问:http://www.eoeandroid.com/forum.php)