这是阿里电话面试里问我的一个问题,当时答得并不好,因为不太了解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具有自己的日志统计。
Myb