hibernate:全自动全映射ORM(Object Relation Mapping)框架,旨在消除sql,HQL(如下图所示)
优点:
1、Hibernate的DAO层开发简单。
2、Hibernate对对象的维护和缓存比较好,对增删改查的对象的维护要方便。
3、Hibernate数据库移植性很好。
4、Hibernate有更好的二级缓存机制,可以使用第三方缓存。
缺点:
1、门槛较高。
2、sql失去了相关的灵活性,解决复杂的增删改查比较困难。
Mybatis:半自动化轻量级框架(如下图所示)
优点:
1、简单易学
mybatis本身就很小且简单。没有任何第三方依赖,最简单安装只要两个jar文件+配置几个sql映射文件易于学习,易于使用,通过文档和源代码,可以比较完全的掌握它的设计思路和实现。
2、灵活
mybatis不会对应用程序或者数据库的现有设计强加任何影响。 sql写在xml里,便于统一管理和优化。通过sql基本上可以实现我们不使用数据访问框架可以实现的所有功能,或许更多。
3、解除sql与程序代码的耦合
通过提供DAL层,将业务逻辑和数据访问逻辑分离,使系统的设计更清晰,更易维护,更易单元测试。sql和代码的分离,提高了可维护性。
4、提供映射标签,支持对象与数据库的orm字段关系映射
5、提供对象关系映射标签,支持对象关系组建维护
6、提供xml标签,支持编写动态sql。
缺点:
1、编写SQL语句时工作量很大,尤其是字段多、关联表多时,更是如此。
2、SQL语句依赖于数据库,导致数据库移植性差,不能更换数据库。
3、框架还是比较简陋,功能尚有缺失,虽然简化了数据绑定代码,但是整个底层数据库查询实际还是要自己写的,工作量也比较大,而且不太容易适应快速数据库修改。
4、二级缓存机制不佳
总结:
根据以上的内容结合相关的应用场景来选择要使用什么样的底层框架。