mybatis和hibernate的对比

本文对比了Mybatis和Hibernate两个ORM框架在性能和实际项目中的应用。Mybatis提供手动编写的SQL,灵活性和可控性更强,适合数据量大、表关联复杂度低且需要深度数据库调优的项目。而Hibernate则通过全自动ORM实现,适用于快速开发,但在大数据量和复杂查询时可能影响性能。
摘要由CSDN通过智能技术生成

mybatis“半自动化”的ORM实现,在于POJO与SQL之间的映射关系。

hibernate “全自动”ORM实现了POJO和数据库表之间的映射,以及 SQL 的自动生成和执行。

SQL优化方面

Hibernate的查询会将表中的所有字段查询出来,性能消耗。

Hibernate也可以自己写SQL来指定需要查询的字段,但这样就破坏了Hibernate开发的简洁性。

Mybatis的SQL是手动编写的,所以可以按需求指定查询的字段。

总的来说,Hibernate使用的是封装好,通用的SQL来应付所有场景,而Mybatis是针对响应的场景设计的SQL。Mybatis的SQL会更灵活、可控性更好、更优化

实际项目关于Hibernate和Mybatis的选型:

1、数据量:有以下情况最好选用Mybatis

如果有超过千万级别的表

如果有单次业务大批量数据提交的需求(百万条及以上的),这个尤其不建议用Hibernate

如果有单次业务大批量读取需求(百万条及以上的)(注,hibernate多表查询比较费劲,用不好很容易造成性能问题)

2、表关联复杂度

如果主要业务表的关联表超过20个(大概值),不建议使用hibernate

3、人员

如果开发成员多数不是多年使用hibernate的情况,建议使用mybatis

4、数据库对于项目的重要程度

如果项目要求对于数据库可控性好,可深度调优,用mybatis

 


 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值