news 2026/5/1 7:18:11

【后端】【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/23 13:50:24

HuggingFace镜像网站收录Qwen3-VL-8B的意义解读

HuggingFace镜像网站收录Qwen3-VL-8B的意义解读 在图像即信息的时代&#xff0c;用户上传一张照片&#xff0c;期望系统不仅能“看见”&#xff0c;还能“理解”——这早已不是科幻场景。从电商平台自动识别商品细节&#xff0c;到客服系统解析用户发来的故障截图&#xff0c;再…

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

SQLite Studio:重新定义数据库探索体验的现代化工具

SQLite Studio&#xff1a;重新定义数据库探索体验的现代化工具 【免费下载链接】sqlite-studio SQLite database explorer 项目地址: https://gitcode.com/gh_mirrors/sq/sqlite-studio 传统数据库管理工具往往陷入功能臃肿或界面陈旧的困境&#xff0c;SQLite Studio以…

作者头像 李华
网站建设 2026/5/1 6:53:43

火山引擎AI大模型之外的选择:高性价比Qwen3-8B深度评测

火山引擎AI大模型之外的选择&#xff1a;高性价比Qwen3-8B深度评测 在当前AI技术加速落地的浪潮中&#xff0c;企业对大语言模型的需求早已从“能不能用”转向了“划不划算、好不好部署”。尤其是当GPT-4、Claude或通义千问Max这类百亿参数巨兽动辄需要数万甚至数十万元的算力投…

作者头像 李华
网站建设 2026/4/23 7:39:20

innodb 更新存储的索引大小以及记录数

innodb 更新存储的索引大小以及记录数 思路&#xff1a; 数据量极小&#xff0c;可以根据行数快速找出我需要的表~ 。mysql8 存储过程解决方案 &#xff0c;谨慎使用&#xff01;&#xff01; 建议本地测试使用 &#xff0c;数据量大的别用&#xff01;&#xff01; DELIMITER…

作者头像 李华
网站建设 2026/5/1 6:44:15

西瓜籽检测与识别——基于YOLOv10n-SOEP的改进实现

&#xff08;1&#xff09; 西瓜籽检测与识别——基于YOLOv10n-SOEP的改进实现 &#xff08;1&#xff09;&#xff08;1&#xff09; 引言 西瓜籽检测与识别在农业自动化和食品安全领域具有重要意义。随着深度学习技术的快速发展&#xff0c;目标检测算法在农产品检测中的应…

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

vLLM推理引擎镜像上线,支持主流模型即载即用

vLLM推理引擎镜像上线&#xff0c;支持主流模型即载即用 在大模型落地进入深水区的今天&#xff0c;企业不再满足于“能不能跑”&#xff0c;而是越来越关注“能不能高效地跑”——高吞吐、低延迟、低成本、易集成。然而现实是&#xff0c;部署一个 LLaMA 或 Qwen 这类7B以上规…

作者头像 李华