1. Mybatis与Hibernate区别
1.1 表格比较
功能 | MyBatis | Hibernate |
---|---|---|
开发速度 | 上手容易 | 相对掌握困难 |
开发工作量 | 手写SQL语句 | 也可以手写SQL语句,但破坏了Hibernate封装和简洁性 |
扩展性 | 因为是手写SQL,所有扩展性好,但迁移性差 | 数据库关系关联都在XML中,所以HQL对是什么数据库不关心 |
移植性 | 不好,针对不同的数据库写不同的SQL | 较好 |
一级缓存 | SQLSession | Session缓存 |
二级缓存 | 在每个具体的表-对象映射中进行详细配置 | 在SessionFactory生成的配置文件中进行详细配置, 然后再在具体的表-对象映射中配置是那种缓存 |
1.2 两者相同点
Hibernate与MyBatis都可以是通过SessionFactoryBuider由XML配置文件生成SessionFactory,然后由SessionFactory 生成Session,最后由Session来开启执行事务和SQL语句。
1.3 两者不同点
- 而MyBatis的优势是MyBatis可以进行更为细致的SQL优化,可以减少查询字段,并且容易掌握。
- Hibernate的优势是DAO层开发比MyBatis简单,Mybatis需要维护SQL和结果映射。
- Hibernate数据库移植性很好,MyBatis的数据库移植性不好,不同的数据库需要写不同SQL。
- Hibernate有更好的二级缓存机制,可以使用第三方缓存。MyBatis本身提供的缓存机制不佳。