Mybatis和Hibernate的区别

iBatis 是 apache 的一个开源项目,一个 O/R Mapping 解决方案,iBatis 最大的特点就
是小巧,上手很快。如果不需要太多复杂的功能,iBatis 是能够满足你的要求又足够灵活的
最简单的解决方案,现在的 iBatis 已经改名为 Mybatis 了。
Hibernate 对数据库结构提供了较为完整的封装,Hibernate 的 O/R Mapping 实现了 POJO
和数据库表之间的映射,以及 SQL 的自动生成和执行。程序员往往只需定义好了 POJO 到
数据库表的映射关系,即可通过 Hibernate 提供的方法完成持久层操作。程序员甚至不需要
对 SQL 的熟练掌握, Hibernate/OJB 会根据制定的存储逻辑,自动生成对应的 SQL 并调
用 JDBC 接口加以执行。
iBATIS 的着力点,则在于 POJO 与 SQL 之间的映射关系。然后通过映射配置文件,
将 SQL 所需的参数,以及返回的结果字段映射到指定 POJO。相对 Hibernate“O/R”而言,
iBATIS 是一种“Sql Mapping”的 ORM 实现。

Hibernate 的调优方案
制定合理的缓存策略;
尽量使用延迟加载特性;
采用合理的 Session 管理机制;
使用批量抓取,设定合理的批处理参数(batch_size);
进行合理的 O/R 映射设计

Mybatis 调优方案
MyBatis 在 Session 方面和 Hibernate 的 Session 生命周期是一致的,同样需要合理
的 Session 管理机制。MyBatis 同样具有二级缓存机制。 MyBatis 可以进行详细的 SQL
优化设计。

SQL 优化方面
Hibernate 的查询会将表中的所有字段查询出来,这一点会有性能消耗。Hibernate 也可
以自己写 SQL 来指定需要查询的字段,但这样就破坏了 Hibernate 开发的简洁性。而 Mybatis
的 SQL 是手动编写的,所以可以按需求指定查询的字段。
Hibernate HQL 语句的调优需要将 SQL 打印出来,而 Hibernate 的 SQL 被很多人嫌弃因
为太丑了。MyBatis 的 SQL 是自己手动写的所以调整方便。但 Hibernate 具有自己的日志统
计。Mybatis 本身不带日志统计,使用 Log4j 进行日志记录。

扩展性方面
Hibernate 与具体数据库的关联只需在 XML 文件中配置即可,所有的 HQL 语句与具体
使用的数据库无关,移植性很好。MyBatis 项目中所有的 SQL 语句都是依赖所用的数据库
的,所以不同数据库类型的支持不好。

对象管理
Hibernate 是完整的对象/关系映射解决方案,它提供了对象状态管理(state management)
的功能,使开发者不再需要理会底层数据库系统的细节。也就是说,相对于常见的
JDBC/SQL 持久层方案中需要管理 SQL 语句,Hibernate 采用了更自然的面向对象的视角
来持久化 Java 应用中的数据。
换句话说,使用 Hibernate 的开发者应该总是关注对象的状态(state),不必考虑 SQL
语句的执行。这部分细节已经由 Hibernate 掌管妥当,只有开发者在进行系统性能调优的时
候才需要进行了解。而 MyBatis 在这一块没有文档说明,用户需要对对象自己进行详细的管理。

抓取策略
Hibernate 对实体关联对象的抓取有着良好的机制。对于每一个关联关系都可以详细地
设置是否延迟加载,并且提供关联抓取、查询抓取、子查询抓取、批量抓取四种模式。它是
详细配置和处理的。而 Mybatis 的延迟加载是全局配置的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值