news 2026/2/2 2:02:59

【后端】【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/1/28 21:58:45

Transformers模型详解:Qwen3-VL-8B的位置编码机制研究

Qwen3-VL-8B 多模态位置编码深度解析&#xff1a;从设计到落地 在当前多模态AI迅猛发展的背景下&#xff0c;如何让模型真正“看懂”图像并“理解”文本之间的空间与语义关系&#xff0c;成为视觉-语言任务的核心挑战。以图文检索、视觉问答&#xff08;VQA&#xff09;和图像描…

作者头像 李华
网站建设 2026/2/1 1:28:24

9款AI写论文哪个好?我为你拨开迷雾,找到那个兼顾“真实感”与“专业度”的学术副驾驶宏智树AI

深夜的图书馆里&#xff0c;键盘声敲碎了寂静&#xff0c;也敲打着一位研究生紧绷的神经。屏幕上&#xff0c;22%的AIGC检测率像一道刺眼的红灯&#xff0c;他刚刚用某款热门AI生成的“完美”初稿&#xff0c;此刻却成了学术诚信的潜在陷阱。 这只是当下AI论文工具浪潮中的一个…

作者头像 李华
网站建设 2026/1/31 13:09:50

解析图漾相机录制的bag视频文件

文章目录前言1.PercipioViewer软件操作步骤1.1 加载录制的bag文件1.2 设置视频播放速度2.C代码解析bag文件2.1 运行编译后的Demo3.常见问题FAQ3.1 编译过程中报错前言 Percipio Viewer 软件支持录制相机采集图像时的视频。录制视频过程中&#xff0c;支持调整部分参数&#xff…

作者头像 李华
网站建设 2026/1/31 11:33:11

transformer架构优化案例:gpt-oss-20b的轻量化实践

Transformer架构优化案例&#xff1a;GPT-OSS-20B的轻量化实践 在消费级笔记本上运行一个参数量超过200亿的语言模型&#xff0c;听起来像是天方夜谭。然而&#xff0c;随着稀疏激活、结构化训练和高效推理技术的融合突破&#xff0c;这一设想正逐步成为现实。GPT-OSS-20B 就是…

作者头像 李华
网站建设 2026/2/1 17:14:58

Mem Reduct终极内存优化指南:从卡顿到极速的完美蜕变

Mem Reduct终极内存优化指南&#xff1a;从卡顿到极速的完美蜕变 【免费下载链接】memreduct Lightweight real-time memory management application to monitor and clean system memory on your computer. 项目地址: https://gitcode.com/gh_mirrors/me/memreduct 还在…

作者头像 李华