`

Ibatis or Hibernate or Spring jdbcTemplate?

阅读更多

为什么使用ibatis而不用spring jdbcTemplate

 

1:ibatis仅仅是对jdbc薄薄的一层封装,完全不丧失sql的灵活性 

2:ibatis所有的sql都可以放在配置文件中,这样有利于sql的集中管理,特别是在sql tuning是很容易把得到所有的sql,如果使用spring jdbctemplate,那么难免要在sql adv上调试好了sql,然后在粘贴到java代码中,会有一大堆的StringObj+=和 StringBufferObj.append() ,如果sql 很长,那么总是copy , paste 也很烦,ibatis没有这样的问题。 

3:ibatis可以把查出的结果集自动mapping成po,不用写一行代码,只需配置一下ResultMap参数即可,而jdbcTemplate大多数情况都要手动的mapping或者实现MappingSqlQuery,ResultSetExtractor等,无论如何都要编程,这些都是体力活,如果使用了ibatis,这些体力活完全可以省去。 

4:ibatis内置cache机制,同时还可以和osCache集成,cache的也是可以配置的,如果配置得当可以大大提高程序性能。 

5:ibatis支持动态sql,不需要在java里有那么多if, else,完全可配置

 

 

 

为什么用ibatis不用Hibernate?

 

  我已经用了hibernate好多年了,现在也要转型,因为hibernate多变查询的表现实在太差还有一查就是一个表所有字段要么就是自己写构造函数 查询时候new 我感觉太失去灵活性了,无法接受,虽然我们现在还是用hibernate但是我决定转型了

1. iBatis 易于掌握。拿来文档看半天到两天就可以掌握了。

   Hibernate 可能需要 3 倍以上的时间来掌握。

 

2. iBatis 更容易进行 sql 的 优化。

 

   这个应该大家都有共识了。另外 Hibernate 生成的 sql 也实在是太难看了。鉴

   于有的朋友提到了 sql 不太重要。我想在这里强调一下我的经验,一般系统性能

   的瓶颈都在数据库上。所以这一点是 iBatis 非常重要的一个优势。

 

3. iBatis 可以进行细粒度的优化

 

   3.1 比如说我有一个表,这个表有几个或者几十个字段,我需要更新其中

       的一个字段,iBatis 很简单,执行一个sql

       UPDATE TABLE_A SET column_1=#column_1# WHERE id=#id#

       但是用 Hibernate 的话就比较麻烦了,缺省的情况下 hibernate 会更新所有字段。

       当然我记得 hibernate 有一个选项可以控制只保存修改过的字段,但是我不太确

       定这个功能的负面效果。

 

   3.2 我需要列出一个表的部分内容,用 iBatis 的时候,这里面的好处是可以少从数据

     库读很多数据,节省流量

       SELECT ID, NAME FROM TABLE_WITH_A_LOT_OF_COLUMN WHERE ...

 

     3.2.1 一般情况下

     Hibernate 会把所有的字段都选出来。比如说有一个上面表有8个字段,

     其中有一两个比较大的字段,varchar(255)/text。上面的场景中我为什么要把他

     们也选出来呢?

 

     3.2.2 用 hibernate 的话,你又不能把这两个不需要的字段设置为 lazy load,因

     为还有很多地方需要一次把整个 domain object 加载出来。这个时候就能显现出

     ibatis 的好处了

 

     3.2.3 Hibernate 还有一个方案,就是生成 javabean/map/object[](感谢

     leelun/cjmm),但是这样的话就可能会产生大量的多余 class。map/object[] 的方式

     应该不错,我比较喜欢这种方式。

 

   3.3 如果我需要更新一条记录(一个对象),如果使用 hibernate,需要现把对

     象 select 出来,然后再做 update。这对数据库来说就是两条 sql。而 iBatis

     只需要一条 update 的 sql 就可以了。减少一次与数据库的交互,对于性能的

     提升是非常重要。

 

4. 开发方面

   4.1 开发效率上,我觉得两者应该差不多

   4.2 可维护性方面,我觉得 iBatis 更好一些。因为 iBatis 的 sql 都保存到

       单独的文件中。而 Hibernate 在有些情况下可能会在 java 代码中保存

       sql/hql。

 

 

5. 运行效率

   5.1 在不考虑 cache 的情况下,iBatis 应该会比hibernate 快一些或者很多

      (根据实际情况会有所不同)。

 

当然 iBatis 也有比较大的缺点

1. 不同数据库类型的支持不好,如果你要开发的系统是要在对中数据间移植,那可能用 hibernate 比较好。

2. 缺省的 cache 支持不好,但是 hibernate 的 cache 支持其实也不是很好,而且很复杂。尤其是对于大并发量的应用。所以我更倾向于自己管理 cache。

分享到:
评论

相关推荐

    Spring iBatis Learning Notes

    Java JDBC作为低级别的API,在实际应用中存在诸多不便之处,因此业界尝试通过多种方式对其进行增强,比如EJB、JDO、Hibernate、Toplink(来自Oracle)、iBatis、SQL Executor以及Spring JDBC支持等技术。 #### 二、...

    spring+ibatis所需jar包

    Spring通过其DataSourceTransactionManager可以管理iBATIS的事务,而Spring的JdbcTemplate或MyBatis-Spring库可以帮助无缝集成这两者,使得业务逻辑代码更加简洁。 在压缩包中列出的"Spring所需jar"可能包括了...

    Spring and iBATIS

    Java的JDBC API尽管功能强大,但在实际应用中显得较为底层且复杂,因此业界出现了多种技术来增强其功能,如EJB、JDO、Hibernate、Toplink(来自Oracle)、iBATIS、SQLExecutor以及Spring框架提供的JDBC支持等。...

    struts2+spring+ibatis +oracle整合 列子

    在Spring框架中,可以通过配置数据源、事务管理器以及JdbcTemplate或MyBatis的SqlSessionFactory来实现与Oracle数据库的连接。 在“struts2+spring+ibatis +oracle整合 列子”中,我们可以预期文件`s2sabatis`包含...

    org.springframework.orm.jar.zip

    Spring ORM模块就是Spring框架对ORM技术的支持,它提供了与Hibernate、JPA、iBatis等主流ORM框架的集成,简化了数据访问层的开发。 二、Spring ORM核心组件 1. Hibernate支持:Spring提供了全面的Hibernate支持,...

    spring_demo

    7. **Spring 数据访问支持**:除了 iBATIS,Spring 还提供了 JdbcTemplate、Hibernate、JPA 等多种数据访问技术的支持,以适应不同的 ORM(对象关系映射)需求。 8. **Spring Boot**:虽然标题没有提到,但通常 ...

    spring-orm源码

    Spring-ORM是Spring框架的一部分,主要负责数据库操作的抽象和集成,它支持多种持久层技术,如Hibernate、JPA、iBatis等。通过阅读和理解Spring-ORM的源码,我们可以深入理解Spring如何与ORM(对象关系映射)框架...

    dao.rar_spring-dao

    Spring的DAO支持包括了JDBC模板、Hibernate和iBatis等ORM工具的集成,以及声明式和编程式事务管理。这些功能可以帮助开发者编写更简洁、更易于测试的DAO类。 根据"压缩包子文件的文件名称列表",我们有两个文件:...

    Spring中文帮助文档

    2.6.4. 将Spring 应用程序上下文部署为JCA adapter 2.6.5. 计划任务 2.6.6. 对Java 5 (Tiger) 支持 2.7. 移植到Spring 2.5 2.7.1. 改变 2.8. 更新的样例应用 2.9. 改进的文档 I. 核心技术 3. IoC(控制反转)...

    spring2.0和spring2.5 及以上版本的jar包区别 spring jar 包详解

    8. **spring-orm.jar**:提供了对多种ORM框架的支持,如Hibernate、iBatis、JDO等。对于Hibernate的支持,由于Spring本身已经提供了很好的支持,所以在这个包中并没有特别强调。 9. **spring-remoting.jar**:提供...

    Spring Framework 2.0开发参考手册(中文版chm)

    在数据访问集成方面,Spring提供了对各种持久层技术的支持,如JDBC、Hibernate、iBatis和JPA等。Spring的JdbcTemplate和HibernateTemplate提供了简洁的API,用于执行数据库操作,同时降低了与数据库交互的复杂性。...

    Spring 高级编程

    Spring对数据库操作提供了广泛的支持,包括传统的JDBC操作和现代的ORM框架如Hibernate、iBATIS(现称为MyBatis)的集成。通过`JdbcTemplate`类,Spring简化了JDBC的编码工作,提供了执行SQL语句、处理结果集等功能,...

    spring几种Dao支持配置

    Spring通过`JdbcTemplate`和`SimpleJdbcInsert`等类提供了对JDBC的抽象,减少了直接使用JDBC代码的繁琐性。`JdbcTemplate`提供了一组模板方法,如`queryForList`、`update`等,用于执行SQL查询和更新操作。`...

    spring3.1.1常用jar包

    6. **Spring ORM**:这个模块整合了流行的对象关系映射(ORM)框架,如Hibernate、JPA、iBatis等,提供了统一的接口进行数据访问。 7. **Spring Web**:包含Spring MVC和Web上下文模块,用于构建基于Servlet的Web...

    Spring 全部 jar包

    10. **spring-orm.jar**:提供了与ORM(Object-Relational Mapping,对象关系映射)框架的集成,如Hibernate、JPA(Java Persistence API)和iBatis。这使得Spring能够与这些ORM框架无缝协作,简化数据访问层的实现...

    跟我学spring3(8-13).pdf

    - **iBATIS集成**:Spring与iBATIS结合,可以方便地管理SQL Maps和Data Access Objects(DAOs),并提供事务管理。 - **JPA集成**:Spring支持Java Persistence API(JPA),提供了透明的事务管理和实体管理功能,...

    Spring3.0.5所有jar包及每个jar包作用说明文档

    8. **spring-orm.jar**:提供与ORM(Object-Relational Mapping)框架的集成,如Hibernate、JPA、iBatis等,使得Spring可以更好地与这些ORM工具协同工作。 9. **spring-web.jar**:提供了基于HTTP的基础网络支持,...

    Spring-Reference_zh_CN(Spring中文参考手册)

    11.2.1. JdbcTemplate类 11.2.2. NamedParameterJdbcTemplate类 11.2.3. SimpleJdbcTemplate类 11.2.4. DataSource接口 11.2.5. SQLExceptionTranslator接口 11.2.6. 执行SQL语句 11.2.7. 执行查询 11.2.8. 更新...

    spring-4.2.1所需jar包

    6. **Spring ORM**: 为其他ORM框架(如Hibernate、JPA、iBatis等)提供了集成,使得在Spring应用中使用这些框架变得更加简单。 7. **Spring Transaction**: 提供了统一的事务管理接口,可以处理各种数据源的事务...

Global site tag (gtag.js) - Google Analytics