IBATIS的工作原理(1)(http://blog.csdn.net/chen861201/article/details/7614201)

这段时间闲来无事重新研究下SSH和SSI的模型,以前写过一篇关于Hibernate对JDBC的封装的文章,这不就再来写一篇Ibatis的。

相对于Hibernate的一站式ORM解决方案而言,Ibatis则是一种半自动化的ORM的实现方案了,怎么说呢,大家看Hibernate是对数据库结构提供了较为完整的封装,提供了POJO到数据库表的全套映射机制,我们要做的就是配置好配置文件和POJO以及他们之间的映射关系即可,即便是你不懂SQL语句,也能进行开发使用。可是往往这种情况下就稍微的有点儿局限性,对于有些需求来说不容易满足,并且不利于sql的优化等。这时我们就更多的考虑到了轻量级的Ibatis这种半自动的实现形式了。要知道Ibatis的优点在于,它仅仅实现的是POJO与sql之间的映射关系,具体的sql语句需要我们自己来写才行。然后通过Ibatis的配置文件将sql所需的参数,以及返回的结果字段映射到指定的POJO。从而达到ORM效果.下面让我们来一一介绍Ibatis的配置文件以及核心函数:

1.Ibatis的实例配置文件及jdbc的配置:

[html]  view plain  copy
  1. <sqlMapConfig>  
  2.     <properties resource="SqlMap.properties"/>这里是jdbc的配置文件  
  3.     <transactionManager type="JDBC">  
  4.         <dataSource type="SIMPLE">  
  5.          <property value="${driver}" name="JDBC.Driver"/>  
  6.          <property value="${url}" name="JDBC.ConnectionURL"/>  
  7.          <property value="${username}" name="JDBC.Username"/>  
  8.          <property value="${password}" name="JDBC.Password"/>  
  9.           
  10.         </dataSource>  
  11.       
  12.     </transactionManager>  
  13.        <sqlMap resource="ncut/com/map/Student.xml"/>这里是POJO与sql语句的映射文件  
  14.      
  15.    </sqlMapConfig>  
2.POJO的基础类文件:

[html]  view plain  copy
  1. public class Student {  
  2.     private int id;  
  3.     private String username;  
  4.     private String password;  
  5.     private int age;  
  6.     /**  
  7.      * @return the id  
  8.      */  
  9.     public int getId() {  
  10.         return id;  
  11.     }  
  12.     /**  
  13.      * @param id the id to set  
  14.      */  
  15.     public void setId(int id) {  
  16.         this.id = id;  
  17.     }  
3.sql的映射文件:

[html]  view plain  copy
  1. <sqlMap>  
  2.     <typeAlias alias="Student" type="ncut.com.bean.Student"/><!-- 其实就是将bean的替换成一个短的名字 -->  
  3.     <select id="selectAllStudent" resultClass="Student">  
  4.         select * from student1  
  5.     </select>  
  6.     <!-- parameterClass  和 parameterMap都是参数类型  
  7.          resultClass resultMap都是返回值类型  -->  
  8.     <select id="selectStudentById" parameterClass="int" resultClass="Student">  
  9.         select * from student1  
  10.         where id=#id#  
  11.     </select>  
  12.       
  13.     <insert id="addStudent" parameterClass="Student">  
  14.         insert student1(id,username,password,age)  
  15.         values  (#id#,#username#,#password#,#age#)  
  16.     </insert>  
  17. </sqlMap>  
4.SqlMapClient是Ibatis运作的核心,所有的数据库操作都是通过SqlMapClient实例来完成的。

XmlSqlMapClientBuilder是ibatis的组件,是用来根据配置文件创建SqlMapClient实例的:

[html]  view plain  copy
  1. private static SqlMapClient sqlMapClient;  
  2.     static{  
  3.         try {  
  4.             Reader reader=com.ibatis.common.resources.Resources.getResourceAsReader("SqlMapConfig.xml");  
  5.                
  6.             sqlMapClient=com.ibatis.sqlmap.client.SqlMapClientBuilder.buildSqlMapClient(reader);  
  7.             reader.close();  
  8.         } catch (IOException e) {  
  9.             // TODO Auto-generated catch block  
  10.             e.printStackTrace();  
  11.         }  
  12.     }  
然后就可以直接调用 SqlMapClient中的方法,进行数据库的CRUD了

你可能感兴趣的:(IBATIS的工作原理(1)(http://blog.csdn.net/chen861201/article/details/7614201))