Hibernate和Mybatis的区别
Posted sunsfan
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Hibernate和Mybatis的区别相关的知识,希望对你有一定的参考价值。
这是阿里电话面试里问我的一个问题,当时答得并不好,因为不太了解Mybatis,所以只是说了自己对Hibernate的一些理解,现在搜集了一些资料,把Hibernate和Mybatis的区别总结如下:
1.概念简介:Hibernate对数据库结构提供了较为完整的封装,Hibernate的O/R Mapping实现了POJO 和数据库表之间的映射,以及SQL 的自动生成和执行。程序员只需定义好了POJO 到数据库表的映射关系,即可通过Hibernate 提供的方法完成持久层操作。同时Hibernate/OJB 会根据制定的存储逻辑,自动生成对应的SQL 并调用JDBC 接口加以执行。而Mybatis则着眼于POJO 与SQL之间的映射关系,通过映射配置文件,将SQL所需的参数,以及返回的结果字段映射到指定POJO。相对Hibernate“O/R”而言,iBATIS 是一种“Sql Mapping”的ORM实现。
2.调优方案:
Hibernate:制定合理的缓存策略;尽量使用延迟加载特性;采用合理的Session管理机制;使用批量抓取,设定合理的批处理参数(batch_size);进行合理的O/R映射设计。
Mybatis:具有二级缓存机制;可以进行详细的SQL优化设计。
3.SQL优化:
Hibernate:Hibernate的查询会将表中的所有字段查询出来,有性能消耗,也可以自己写SQL来指定需要查询的字段,但这样就破坏了Hibernate开发的简洁性,Hibernate具有自己的日志统计。
Mybatis:Mybatis的SQL是手动编写的,所以可以按需求指定查询的字段,调整方便,Mybatis本身不带日志统计,使用Log4j进行日志记录。
4.扩展方面:
Hibernate:Hibernate与具体数据库的关联只需在XML文件中配置即可,所有的HQL语句与具体使用的数据库无关,移植性很好。
Mybatis:MyBatis项目中所有的SQL语句都是依赖所用的数据库的,所以不同数据库类型的支持不好。
5.对象管理:
Hibernate:完整的对象/关系映射解决方案,它提供了对象状态管理(state management)的功能,使开发者不再需要理会底层数据库系统的细节。
Mybatis:需要用户自己管理对象。
6.抓取策略:
Hibernate:Hibernate对实体关联对象的抓取有着良好的机制。对于每一个关联关系都可以详细地设置是否延迟加载,并且提供关联抓取、查询抓取、子查询抓取、批量抓取四种模式,它是详细配置和处理的。
Mybatis:延迟加载是全局配置的。
总结:
Hibernate和Mybatis相同点:都可以通过SessionFactoryBuider由XML配置文件生成SessionFactory,然后由SessionFactory 生成Session,最后由Session来开启执行事务和SQL语句。其中SessionFactoryBuider,SessionFactory,Session的生命周期都是差不多的。都支持JDBC和JTA事务处理。
Hibernate和Mybatis不同点:
Hibernate:Hibernate的DAO层开发比MyBatis简单,Mybatis需要维护SQL和结果映射。Hibernate对对象的维护和缓存要比MyBatis好,对增删改查的对象的维护要方 便。Hibernate数据库移植性很好,MyBatis的数据库移植性不好,不同的数据库需要写不同SQL。Hibernate有更好的二级缓存机制,可以使用第三方缓存。MyBatis本身提 供的缓存机制不佳。
Mybatis:MyBatis可以进行更为细致的SQL优化,可以减少查询字段。MyBatis容易掌握,而Hibernate门槛较高。
参考文章地址:http://blog.csdn.net/firejuly/article/details/8190229
以上是关于Hibernate和Mybatis的区别的主要内容,如果未能解决你的问题,请参考以下文章