news 2026/4/16 13:59:54

【后端】【Java】一文搞懂 JDBC、MyBatis、JPA 的区别与底层原理

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【后端】【Java】一文搞懂 JDBC、MyBatis、JPA 的区别与底层原理

一文搞懂 JDBC、MyBatis、JPA 的区别与底层原理

在 Java 后端开发中,数据库访问层(DAO / Repository)几乎是每个项目的核心。
而在实际开发中,我们最常见的三种方案是:

  • JDBC(最底层)

  • MyBatis(半自动 ORM)

  • JPA / Hibernate(全自动 ORM)

很多初学者会有这些疑问:

🤔 JDBC、MyBatis、JPA 到底差在哪?
🤔 为什么公司不用 JDBC?
🤔 MyBatis 为什么还能写 SQL?
🤔 JPA 为什么“简单但慢”?

本文将从底层原理 + 实战角度带你一次彻底搞懂。


一、整体分层视角(先有全局概念)

抽象程度来看:

JPA(Hibernate) ↑ MyBatis ↑ JDBC

工作量与控制力来看:

技术抽象层级SQL 控制开发效率
JDBC最低⭐⭐⭐⭐⭐
MyBatis中等⭐⭐⭐⭐⭐⭐⭐
JPA最高⭐⭐⭐⭐⭐⭐⭐

二、JDBC:最原始、最底层的数据库访问方式

1️⃣ JDBC 是什么?

JDBC(Java Database Connectivity)是 Java 官方提供的一套数据库访问 API 标准

👉 本质:Java 代码直接操作数据库


2️⃣ JDBC 的核心流程

Connection conn = DriverManager.getConnection(url, user, pwd); PreparedStatement ps = conn.prepareStatement("select * from user where id=?"); ps.setInt(1, 1); ResultSet rs = ps.executeQuery(); while (rs.next()) { System.out.println(rs.getString("name")); }

JDBC 做了什么?

  1. 加载数据库驱动

  2. 建立数据库连接

  3. 手写 SQL

  4. 设置参数

  5. 执行 SQL

  6. 解析 ResultSet

  7. 手动关闭资源

👉几乎所有细节都要你自己处理


3️⃣ JDBC 的优缺点

✅ 优点:

  • 性能最好(最少封装)

  • 完全掌控 SQL

  • 学习数据库原理必经之路

❌ 缺点:

  • 模板代码极多

  • 易出错(忘关连接)

  • 代码可读性差

  • 不适合大型项目


4️⃣ JDBC 的真实定位

JDBC 是“地基”,不是“商品房”

📌 实际开发中:

  • JDBC 很少直接使用

  • MyBatis / JPA 底层最终都是 JDBC


三、MyBatis:半自动 ORM(SQL 仍在你手中)

1️⃣ MyBatis 是什么?

MyBatis = JDBC + SQL 映射 + 动态 SQL

👉 核心思想:

SQL 我来写,对象你来帮我映射


2️⃣ MyBatis 的核心架构

Mapper 接口 ↓ XML / 注解 SQL ↓ MyBatis Executor ↓ JDBC ↓ Database

3️⃣ MyBatis 工作原理(重点)

以一次查询为例:

  1. 调用 Mapper 接口方法

  2. MyBatis 找到对应 SQL(XML / 注解)

  3. 解析#{}参数

  4. 生成 PreparedStatement

  5. 通过 JDBC 执行 SQL

  6. 自动封装 ResultSet → Java 对象

  7. 返回结果

👉你只负责 SQL 和接口,JDBC 细节 MyBatis 帮你搞定


4️⃣ MyBatis 示例

@Mapper public interface UserMapper { User selectById(Long id); }
<select id="selectById" resultType="User"> select * from user where id = #{id} </select>

5️⃣ MyBatis 的优势

✅ 优点:

  • SQL 可控(非常适合复杂查询)

  • 动态 SQL 强大

  • 学习成本低

  • 性能可预测

  • 国内使用最广泛

❌ 缺点:

  • SQL 与 Java 分离(维护成本)

  • CRUD 代码仍偏多

  • 对象关系映射能力有限


6️⃣ MyBatis 适合谁?

📌强 SQL 驱动项目

  • 金融系统

  • 报表系统

  • 数据分析系统

  • 历史项目改造


四、JPA:真正的 ORM(面向对象操作数据库)

1️⃣ JPA 是什么?

JPA(Java Persistence API)是一套ORM 规范,不是实现。

常见实现:

  • Hibernate(最常用)

  • EclipseLink

👉 核心思想:

把数据库当成对象集合来操作


2️⃣ JPA 的核心概念

概念含义
Entity数据库表
EntityManager数据操作入口
Persistence Context一级缓存
JPQL面向对象的查询语言

3️⃣ JPA 的工作原理

@Entity @Table(name = "user") class User { @Id private Long id; private String name; }
userRepository.findById(1L);
内部发生了什么?
  1. JPA 解析实体映射

  2. 根据方法名 / JPQL 生成 SQL

  3. Hibernate 生成 JDBC SQL

  4. 执行 SQL

  5. 结果放入一级缓存

  6. 返回实体对象

👉你几乎看不到 SQL


4️⃣ JPA 的“黑魔法”能力

  • 方法名生成 SQL

    findByNameAndAge()
  • 自动脏检查(不用手写 update)

  • 级联保存 / 删除

  • 对象关系自动管理


5️⃣ JPA 的优缺点

✅ 优点:

  • CRUD 开发效率极高

  • 面向对象思维

  • 代码极简

  • 非常适合业务系统

❌ 缺点:

  • SQL 不直观

  • 学习曲线陡

  • 复杂查询性能不易掌控

  • 调优成本高


五、三者核心对比总结(必看)

维度JDBCMyBatisJPA
抽象程度⭐⭐⭐⭐⭐⭐⭐⭐
SQL 控制最强
开发效率最低最高
学习成本
性能可控⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐
适合项目底层复杂 SQL业务系统

六、真实项目中该怎么选?

✅ 选择建议(经验之谈)

🟢 用 MyBatis 的情况
  • SQL 复杂

  • 强调性能

  • 需要精确控制查询

  • 国内传统项目

🟢 用 JPA 的情况
  • CRUD 为主

  • 业务变化快

  • 表结构相对稳定

  • 追求开发效率

🟢 JDBC 什么时候用?
  • 写框架

  • 学原理

  • 极端性能场景


七、混合使用是最佳实践

JPA + MyBatis 并不冲突

常见组合:

  • JPA:80% CRUD

  • MyBatis:20% 复杂 SQL

Spring Boot 中非常常见 👍


八、一句话总结

JDBC 是基础,MyBatis 是工程利器,JPA 是效率神器

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

Rust语言开发者的新工具:Seed-Coder-8B-Base代码支持上线

Rust语言开发者的新工具&#xff1a;Seed-Coder-8B-Base代码支持上线 在现代系统编程领域&#xff0c;Rust以其内存安全与高性能的双重优势&#xff0c;正逐步成为操作系统、嵌入式系统乃至WebAssembly场景下的首选语言。然而&#xff0c;这种强大能力的背后&#xff0c;是陡峭…

作者头像 李华
网站建设 2026/4/11 5:10:35

Nginx负载均衡部署多个ACE-Step实例:应对大规模访问需求

Nginx负载均衡部署多个ACE-Step实例&#xff1a;应对大规模访问需求 在短视频、游戏和影视内容爆发式增长的今天&#xff0c;对背景音乐的自动化生成需求正以前所未有的速度攀升。一个热门短视频可能需要数十种风格各异的配乐进行A/B测试&#xff0c;而一部动画电影则涉及成百上…

作者头像 李华
网站建设 2026/4/16 4:36:17

DS4Windows终极配置指南:释放PS4手柄在PC上的全部潜能

问题定位&#xff1a;为什么你的PS4手柄在PC上表现不佳&#xff1f; 【免费下载链接】DS4Windows Like those other ds4tools, but sexier 项目地址: https://gitcode.com/gh_mirrors/ds/DS4Windows 许多玩家发现将PlayStation手柄连接到PC时&#xff0c;会遇到兼容性差…

作者头像 李华
网站建设 2026/4/11 18:57:31

ParsecVDD虚拟显示器完整指南:从入门到精通

ParsecVDD虚拟显示器完整指南&#xff1a;从入门到精通 【免费下载链接】parsec-vdd ✨ Virtual super display, upto 4K 2160p240hz &#x1f60e; 项目地址: https://gitcode.com/gh_mirrors/pa/parsec-vdd ParsecVDD是一款功能强大的虚拟显示器工具&#xff0c;能够为…

作者头像 李华