hibernate和mybatis的对比分析以及技术选型

来源:互联网 发布:matlab 稀疏矩阵转换 编辑:程序博客网 时间:2024/05/05 06:38
一.先来说一下hibernate 和mybatis的优缺点
1.学习开发上手上: hibernate的封装功能和特性很多, 所以对开发人员要求很高
2.系统调优SQL优化:
hibernate制定合理的缓存机制, 尽量使用延迟加载, 合理采用session管理机制, 设置合理的批量处理参数(batch-size)使用批量抓取, 进行合理的O/R映射设计. 但是hibernate查询会查询所有字段, 如果要查询指定字段需要自己写SQL,这样就破坏了hibernate的开发简洁性.
mybatis在session方面和hibernate的session生命周期是一致的,同样需要合理的session管理机制,但是由于mybatis的SQL是手动编写的可以进行SQL优化
3.可移植性
hibernate使用时封装好通用的SQL来对应所有场景,与数据库的关联只需在xml文件中配置机即可,所有的Hql语句与具体数据库无关,移植性好
mybatis是针对不同场景设计SQL,更灵活,可控性好,但是所有SQL都是依赖数据库的,可移植性不好
4.功能性能上
hibernate功能丰富,对jdbc进行了一次封装, 不支持动态的SQL, 操作多表数据量大的查询很难实现很复杂
mybatis功能有限但是支持plugin进行扩展,基于原生的jdbc支持动态SQL,性能远远优于hibernate ,对应大数据量的查询相对简单
二.关于hibernate 和mybatis的选型,在面对开发时到底选哪个框架更合适?
1.数据量有超千万级别的表数据,单次业务大批量提交/查询(百万级),可以优先选取mybatis
2.关联表超过20以上的,建议不适用hibernate, 要求对数据库的可控性好,可以深度调优选择mybatis
3.如果开发人员不是多年使用hibernate的情况下建议使用mybatis