Mybaits的优点&缺点?

大家好,我是锋哥。今天分享关于【Mybaits的优点&缺点?】面试题。希望对大家有帮助;

Mybaits的优点&缺点?

超硬核AI学习资料,现在永久免费了!

下面是 MyBatis(一个常用的 Java 持久层框架)的主要优点和缺点整理:


✅ MyBatis 的优点

1. SQL 可控性强

你可以 完全自定义 SQL,对 SQL 语句的执行方式、优化策略、索引使用等有高度控制,不像 Hibernate 那样自动生成SQL 有时难优化。

2. 灵活性高

支持复杂 SQL,比如多表联查、动态 SQL、分页、复杂统计等,在处理复杂查询逻辑时非常方便。

3. 学习曲线低

与 JPA/Hibernate 相比更简单直接,只需熟悉基本 SQL 和少量映射配置即可上手。

4. 性能可预测

由于 SQL 手写可控,不存在自动生成低效 SQL 的问题,性能更容易调优和预测。

5. 良好的可扩展性

支持插件扩展(像分页插件、性能拦截检查等),也能和 Spring/Spring Boot 无缝集成。

6. 文档友好

注解 + XML 结合的方式能让 SQL 与映射(Mapper)清晰分离,方便管理。


⚠️ MyBatis 的缺点

1. 工作量较大

SQL 需要手写,大量 CRUD 时需要写很多重复的 SQL 和映射文件,在业务量大时显得繁琐。

2. 维护成本较高

SQL 分散在 XML 或注解里,业务变更时需要手动修改 SQL,项目规模大时维护不易。

3. 对象关系映射(ORM)能力弱

不像 Hibernate 那样拥有强大的一对多/多对多自动关联映射和缓存机制,需要手动处理关联关系

4. 缺少自动缓存机制

默认只有一级缓存(Session 级别),没有二级缓存,需要自己实现或引入外部缓存。

5. 动态 SQL 代码繁琐

虽然支持 <if><where><foreach> 等动态 SQL,但写起来比 JPA Criteria/QueryDSL 逻辑略繁琐、难读。


🆚 MyBatis vs Hibernate(或其他 ORM)对比感受

对比项MyBatisHibernate
SQL 控制⭐⭐⭐⭐⭐⭐⭐⭐
学习曲线⭐⭐⭐⭐⭐⭐⭐
复杂查询⭐⭐⭐⭐⭐⭐
自动 ORM⭐⭐⭐⭐⭐⭐
开发速度(CRUD)⭐⭐⭐⭐⭐⭐
性能可预测性⭐⭐⭐⭐⭐⭐⭐

🧠适用场景总结

✅ 需要完全自定义 SQL
✅ 高性能、复杂 SQL 场景
✅ 维护团队擅长 SQL 优化
❌ 业务逻辑简单CRUD 且追求开发效率
❌ 需要大规模对象图自动关联映射

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值