news 2026/6/23 11:24:20

为什么Java程序员喜欢抱着Java8,守着mybatis写xml?(不用orm) ?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
为什么Java程序员喜欢抱着Java8,守着mybatis写xml?(不用orm) ?

这个现象在中国Java后端圈确实非常普遍(尤其是中大厂和传统互联网/金融/政府项目),甚至到2025–2026年仍然是大主流技术选型。核心原因可以归纳为下面几点,基本是历史路径依赖 + 现实生产约束 + 文化偏好的叠加结果:

为什么还抱着Java 8?

  1. 稳定性压倒一切
    Java 8 是第一个长期支持版(虽然Oracle官方早已不提供免费更新,但各种OpenJDK发行版如Zulu、Adoptium、龙井、Tencent Kona等都长期维护Java 8),很多公司内部把“不出事”放在第一位。

  2. 生态最成熟、最便宜的版本

    • Spring Boot 2.x 主力版本就是基于Java 8
    • 无数中间件、组件、Agent(skywalking、arthas、sentinel、nacos、seata……)最稳的版本都是Java 8
    • 升级到11/17/21要重新验证一堆第三方jar、压测、改代码(尤其是用了Unsafe、反射、代理的组件),人力成本巨大
  3. 很多老项目根本动不了
    动一次几百万行代码,动辄半年到一年没人敢碰,业务不敢停,出了问题没人背锅。

为什么守着MyBatis + XML?

  1. SQL掌控感最强(这是最核心的心理因素)
    绝大多数Java程序员(尤其是工作3–10年的)对Hibernate/JPA的HQL/Criteria/自动生成SQL极度缺乏安全感,怕“写着写着就多查了字段/多表关联/隐式笛卡尔积/N+1”。

  2. 性能红线 + 复杂查询场景
    国内互联网/金融项目普遍有以下特点:

    • 报表类查询极多(left join 10+张表、group by、window函数、复杂条件)
    • 经常需要走索引提示、强制走某条索引
    • 要写union、cte、存储过程调用
    • 批量操作要控制批次大小、要看到实际执行的SQL

    MyBatis在这方面几乎无敌,JPA/Hibernate要么写原生SQL(那还不如MyBatis),要么性能调优极其痛苦。

  3. 历史路径依赖 + 人才密度

    • 阿里从iBatis时代就开始大规模使用 → 淘宝/支付宝/钉钉/饿了么/优酷等一堆公司抄阿里技术栈
    • MyBatis招聘成本最低、简历最多、面试最容易对齐
    • 团队里总有1–2个“SQL老人”,他们一反对用JPA,整个团队就继续MyBatis了
  4. “全自动ORM”在国内被打成筛子了
    很多人用过早期MyBatis-Plus / JPA / Spring Data JPA后,遇到下面这些痛点就彻底回MyBatis了:

    场景JPA/Hibernate常见痛点MyBatis写法
    复杂多表查询HQL写崩 / Criteria写到吐 / 最后还是nativeQuery直接写SQL,清晰可控
    性能瓶颈排查很难一眼看出实际SQL日志里就是最终SQL
    批量插入/更新性能一般,容易出脏数据问题foreach + batch
    动态SQL复杂逻辑很难写(case when / 多层if)标签/OGNL/三元/脚本语言
    DBA审核SQL基本不可能审核自动生成的SQLXML/SQL文件可以直接给DBA看

总结一句话

国内Java后端主流技术栈停留在“Java 8 + Spring Boot 2.x + MyBatis XML + MySQL”这个组合,本质上是:

“在当前人力成本、业务稳定性要求、复杂查询占比、团队SQL掌控偏好、人才市场供给”这几个约束条件下,它就是性价比/风险比最高的局部最优解。

想打破这个循环,通常需要下面几者至少满足其一:

  • 公司强力推动技术升级(字节、某些大厂新项目已经大量Java 17/21 + jOOQ / Kotlin Exposed / MyBatis-Plus)
  • 团队里有很强悍的架构/ORM爱好者能把JPA玩出花来
  • 新项目从0开始,且业务场景不以复杂查询为主

你现在项目是用这一套吗?还是已经开始往别的方向走了?

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/14 3:37:42

面试官:只会 Redis?高并发下你的缓存架构怎么设计到极致?

面试官抛出这个问题时,其实是在考察你是否只停留在“会用 Redis”,而是真正理解高并发场景下缓存体系的工程化设计——包括性能边界、热点防护、一致性取舍、高可用、成本等多个维度的权衡。 下面给出一个目前(2026年)互联网中大…

作者头像 李华
网站建设 2026/6/13 19:23:33

仅凭ai真的能做好复杂项目吗?

仅凭 AI 真的能做好复杂项目吗?(2026年1月的真实现状视角) 短期答案(2025–2026年):基本还不行。 目前完全靠 AI 独立完成一个中等以上复杂度的真实项目(比如一个有分布式系统、复杂业务规则、…

作者头像 李华
网站建设 2026/6/13 20:05:33

Nodejs+vue学校高校校园生活综合服务系统小程序

文章目录系统概述技术架构核心功能模块创新点应用价值--nodejs技术栈--结论源码文档获取/同行可拿货,招校园代理 :文章底部获取博主联系方式!系统概述 基于Node.js后端与Vue前端技术栈开发的校园生活综合服务小程序,整合课表查询、食堂订餐、…

作者头像 李华
网站建设 2026/6/22 8:10:03

Nodejs+vue安卓的考研资料学习平台助手app 小程序

文章目录 技术架构设计数据交互优化部署与扩展性能与安全 --nodejs技术栈--结论源码文档获取/同行可拿货,招校园代理 :文章底部获取博主联系方式! 技术架构设计 后端框架:采用Node.js(Express/Koa)搭建RESTful API&am…

作者头像 李华
网站建设 2026/6/22 1:34:26

Java基于Spring Boot+Vue的在线继续教育系统设计与实现

项目说明 随着互联网技术的迅猛发展和普及,继续教育教育领域正经历着前所未有的变革。传统的继续教育教育模式已经无法满足现代社会的多元化需求,特别是在信息爆炸的时代背景下,人们更加追求高效、便捷、个性化的学习方式。互联网技术的广泛应…

作者头像 李华
网站建设 2026/6/22 8:47:48

thinkmyself(1)

这里ATC存的是经过IOMMU翻译的GPA->HAP映射项,还是经过SMMU翻译的GPA->HAP映射项? 1. 核心概念与分工 IOMMU(CPU端):在x86虚拟化环境中,IOMMU(如Intel VT-d)的核心作用是将虚拟机物理地…

作者头像 李华