JDBC 完全指南:掌握 Java 数据库交互的核心技术
JDBC 完全指南:掌握 Java 数据库交互的核心技术
一、JDBC 是什么?为什么它如此重要?
JDBC(Java Database Connectivity)是 Java 语言中用于连接和操作关系型数据库的标准 API。它允许开发者通过统一的接口访问不同的数据库(如 MySQL、Oracle、PostgreSQL 等),而无需关心底层数据库的具体实现。 JDBC是学习Mybatis的前提,Mybatis是JDBC的简化,清楚认识到jdbc的流程,才能更好理解Mybatis。Mybatis明天准时更新。
JDBC 的核心价值
- 跨数据库兼容性:同一套代码适配多种数据库(通过更换驱动即可)。
- 简化开发:封装数据库协议细节,开发者专注于业务逻辑。
- 性能可控:支持从原生 SQL 操作到连接池优化等多层调优。
二、JDBC 架构与核心组件
JDBC 的架构分为两层:
- 应用程序层:开发者编写的 Java 代码。
- 驱动层:数据库厂商提供的 JDBC 驱动(如
mysql-connector-java)。
核心接口与类
| 组件 | 作用 |
|---|---|
DriverManager | 管理数据库驱动,建立与数据库的连接 |
Connection | 表示与数据库的会话,用于管理事务和创建语句对象 |
Statement | 执行静态 SQL 语句(如 SELECT, INSERT) |
PreparedStatement | 预编译 SQL 语句,防止 SQL 注入,提升性能 |
CallableStatement | 调用数据库存储过程 |
ResultSet | 封装查询结果集,支持遍历和读取数据 |
三、JDBC 工作流程详解
6 步完成数据库操作
1. 注册驱动(可选)
从 JDBC 4.0 开始,支持自动驱动加载,无需手动调用 Class.forName()。
// 旧方式(JDBC 3.0)
Class.forName("com.mysql.cj.jdbc.Driver"); // JDBC 4.0+ 自动加载驱动(需驱动 JAR 包含 META-INF/services/java.sql.Driver 文件)
2. 建立连接
通过 DriverManager.getConnection() 获取 Connection 对象。
String url = "jdbc:mysql://localhost:3306/mydb?useSSL=false&serverTimezone=UTC";
String user = "root";
String password = "123456"; try (Connection conn = DriverManager.getConnection(url, user, password)) { // 使用连接执行操作
}
3. 创建 Statement
根据需求选择 Statement 或 PreparedStatement。
// 静态 SQL(存在 SQL 注入风险)
Statement stmt = conn.createStatement(); // 预编译 SQL(推荐)
String sql = "INSERT INTO users(name, email) VALUES (?, ?)";
PreparedStatement pstmt = conn.prepareStatement(sql);
4. 执行 SQL
- 查询:
executeQuery()返回ResultSet。 - 更新:
executeUpdate()返回受影响的行数。
// 插入数据
pstmt.setString(1, "Alice");
pstmt.setString(2, "alice@example.com");
int rows = pstmt.executeUpdate();
System.out.println("插入行数: " + rows); // 查询数据
ResultSet rs = stmt.executeQuery("SELECT * FROM users");
5. 处理结果集
遍历 ResultSet 并读取数据。
while (rs.next()) { int id = rs.getInt("id"); String name = rs.getString("name"); System.out.println(id + ", " + name);
}
6. 关闭资源
使用 try-with-resources 自动关闭资源(Java 7+)。
try (Connection conn = DriverManager.getConnection(url, user, password); PreparedStatement pstmt = conn.prepareStatement(sql); ResultSet rs = pstmt.executeQuery()) { // 操作代码
} catch (SQLException e) { e.printStackTrace();
}
四、PreparedStatement vs Statement:为什么前者更优秀?
| 对比项 | Statement | PreparedStatement |
|---|---|---|
| SQL 注入风险 | 高(直接拼接 SQL) | 低(参数化查询) |
| 性能 | 每次执行需编译 SQL | 预编译一次,重复使用效率高 |
| 可读性 | 字符串拼接复杂 | 参数占位符(?)清晰易读 |
示例:PreparedStatement 防 SQL 注入
String input = "admin'; DROP TABLE users;--"; // 错误方式(Statement)
String sql = "SELECT * FROM users WHERE name = '" + input + "'";
// 实际 SQL: SELECT * FROM users WHERE name = 'admin'; DROP TABLE users;--' // 正确方式(PreparedStatement)
PreparedStatement pstmt = conn.prepareStatement("SELECT * FROM users WHERE name = ?");
pstmt.setString(1, input); // 参数会被安全处理
五、事务管理:保证数据一致性
通过 Connection 对象控制事务:
try (Connection conn = DriverManager.getConnection(url, user, password)) { conn.setAutoCommit(false); // 关闭自动提交 // 执行多个操作 updateAccount(conn, "A", -100); updateAccount(conn, "B", 100); conn.commit(); // 提交事务
} catch (SQLException e) { conn.rollback(); // 回滚事务
}
关键方法:
setAutoCommit(boolean):启用/禁用自动提交。commit():提交事务。rollback():回滚事务。
六、连接池:提升性能的关键
为什么需要连接池?
- 频繁创建/关闭连接开销大。
- 连接池预先创建并管理连接,复用连接减少延迟。
常用连接池库
- HikariCP:高性能,Spring Boot 默认选择。
- Apache DBCP:稳定但性能一般。
- C3P0:功能丰富,但较老旧。
HikariCP 示例配置
HikariConfig config = new HikariConfig();
config.setJdbcUrl("jdbc:mysql://localhost/mydb");
config.setUsername("root");
config.setPassword("123456");
config.setMaximumPoolSize(10); try (HikariDataSource dataSource = new HikariDataSource(config); Connection conn = dataSource.getConnection()) { // 使用连接
}
七、异常处理与最佳实践
1. 处理 SQLException
- 捕获并记录异常,避免直接忽略。
- 使用
SQLException.getErrorCode()获取数据库特定错误码。
2. 最佳实践
- 始终使用 PreparedStatement:防止 SQL 注入。
- 使用 try-with-resources:确保资源释放。
- 合理设置连接池参数:如最大连接数、超时时间。
- 日志记录 SQL 操作:便于调试和审计。
八、进阶:JdbcTemplate 与 ORM 框架
1. Spring JdbcTemplate
简化 JDBC 样板代码:
@Autowired
private JdbcTemplate jdbcTemplate; public List<User> getUsers() { return jdbcTemplate.query("SELECT * FROM users", (rs, rowNum) -> { User user = new User(); user.setId(rs.getInt("id")); user.setName(rs.getString("name")); return user; });
}
2. ORM 框架(如 MyBatis、Hibernate)
- MyBatis:通过 XML/注解映射 SQL,灵活性强。
- Hibernate:全自动 ORM,适合复杂对象模型。
九、完整示例:JDBC CRUD 操作
public class JdbcDemo { private static final String URL = "jdbc:mysql://localhost:3306/mydb"; private static final String USER = "root"; private static final String PASSWORD = "123456"; public static void main(String[] args) { // 插入用户 insertUser("Bob", "bob@example.com"); // 查询用户 List<User> users = getUsers(); users.forEach(System.out::println); } public static void insertUser(String name, String email) { String sql = "INSERT INTO users(name, email) VALUES (?, ?)"; try (Connection conn = DriverManager.getConnection(URL, USER, PASSWORD); PreparedStatement pstmt = conn.prepareStatement(sql)) { pstmt.setString(1, name); pstmt.setString(2, email); pstmt.executeUpdate(); } catch (SQLException e) { e.printStackTrace(); } } public static List<User> getUsers() { List<User> users = new ArrayList<>(); String sql = "SELECT * FROM users"; try (Connection conn = DriverManager.getConnection(URL, USER, PASSWORD); Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery(sql)) { while (rs.next()) { User user = new User(); user.setId(rs.getInt("id")); user.setName(rs.getString("name")); user.setEmail(rs.getString("email")); users.add(user); } } catch (SQLException e) { e.printStackTrace(); } return users; }
}
**十、总结
核心要点回顾
- JDBC 是 Java 操作数据库的标准,通过驱动实现跨数据库兼容。
PreparedStatement比Statement更安全高效。- 事务和连接池是提升性能与稳定性的关键。
掌握 JDBC,您已打通 Java 与数据库的桥梁! 🚀
相关文章:
JDBC 完全指南:掌握 Java 数据库交互的核心技术
JDBC 完全指南:掌握 Java 数据库交互的核心技术 一、JDBC 是什么?为什么它如此重要? JDBC(Java Database Connectivity)是 Java 语言中用于连接和操作关系型数据库的标准 API。它允许开发者通过统一的接口访问不同的数…...
Vue父子组件传递笔记
Vue父子组件传递笔记 props 父组件向子组件进行传值 (1)在父组件APP.vue <template><div> <!-- 给子组件Child.vue传递以msg的信号,传递的信息内容为messages --><Child :msg"messages"></Child>…...
文件上传漏洞与phpcms漏洞安全分析
目录 1. 文件上传漏洞简介 2. 文件上传漏洞的危害 3. 文件上传漏洞的触发条件 1. 文件必须能被服务器解析执行 2. 上传目录必须支持代码执行 3. 需要能访问上传的文件 4. 例外情况:非脚本文件也可能被执行 4. 常见的攻击手法 4.1 直接上传恶意文件 4.2 文件…...
【deepseek】辅助思考生物学问题:ICImapping构建遗传图谱gap较大
基于ICImapping构建遗传图谱的常见问题与解答 问题一:染色体两端标记间遗传距离gap较大 答疑一 标记密度不足(如芯片设计时分布不均)重组概率低基因组结构变异软件算法限制 Deepseek的解释 #### 1. **染色体末端的重组率较低** - **现象*…...
linux磁盘非lvm分区
linux磁盘非lvm分区 类似于windows划分C盘、D盘,并且不需要多个磁盘空间合一 图形化直接分区 通过gparted 这个提供直观的图形化分区,类似windows的磁盘管理工具 下载方式: 乌班图/debian系列: sudo apt install gparted红帽…...
Windows下sql server2012安装流程
准备工作 确认系统要求:确保 Windows 系统为 Windows 7 或更高版本,且为 64 位操作系统,CPU 在 2GHz 以上,内存 4GB 或更高。 下载安装包:从微软官方网站或其他可靠渠道下载 SQL Server 2012 安装包。 关闭相关软件&am…...
css之英文换行样式
在 CSS 中,要实现英文文本自动换行但不从单词中间断开的效果,可以使用 word-wrap 或 overflow-wrap 属性。以下是相关的 CSS 属性和它们的配置: 使用 overflow-wrap 或 word-wrap /* This property is used to handle word breaking */ .wo…...
绝美焦糖暖色调复古风景画面Lr调色教程,手机滤镜PS+Lightroom预设下载!
调色教程 通过 Lr 软件丰富的工具和功能,对风景照片在色彩、影调等方面进行调整。例如利用基本参数调整选项,精准控制照片亮度、对比度、色温、色调等基础要素;运用 HSL 面板可对不同色彩的色相、饱和度以及明亮度进行单独调节;利…...
文件解析:doc、docx、pdf
1.doc解析 ubuntu/debian系统应先安装工具 apt-get install python-dev libxml2-dev libxslt1-dev antiword unrtf poppler-utils pstotext tesseract-ocr \ flac ffmpeg lame libmad0 libsox-fmt-mp3 sox libjpeg-dev swig pip install textract解析: import te…...
计算机网络基础:VLAN(虚拟局域网)
1. VLAN 虚拟局域网:可以用来隔离广播 广播和广播域: arp 出不了路由器,只能攻击内网 路由器可以隔离广播(物理隔离)缺点是成本高、不灵活 2. VLAN 隔离广播 静态VLAN:基于交换机端口号划分 动态VLAN&am…...
C++学习笔记(十一)——循环结构
循环结构的作用 循环结构用于重复执行某一代码块,直到满足特定条件后退出循环。 C 提供了以下三种循环结构: for 循环(确定次数的循环)while 循环(条件控制的循环)do-while 循环(至少执行一次的…...
【C++】二叉树相关算法题
一、根据二叉树创建字符串 题目描述: 给你二叉树的根节点 root ,请你采用前序遍历的方式,将二叉树转化为一个由括号和整数组成的字符串,返回构造出的字符串。 空节点使用一对空括号对 “()” 表示,转化后需要省略所有…...
物联网IoT系列之MQTT协议基础知识
文章目录 物联网IoT系列之MQTT协议基础知识物联网IoT是什么?什么是MQTT?为什么说MQTT是适用于物联网的协议?MQTT工作原理核心组件核心机制 MQTT工作流程1. 建立连接2. 发布和订阅3. 消息确认4. 断开连接 MQTT工作流程图MQTT在物联网中的应用 …...
【大学生体质】智能 AI 旅游推荐平台(Vue+SpringBoot3)-完整部署教程
智能 AI 旅游推荐平台开源文档 项目前端地址 ☀️项目介绍 智能 AI 旅游推荐平台(Intelligent AI Travel Recommendation Platform)是一个利用 AI 模型和数据分析为用户提供个性化旅游路线推荐、景点评分、旅游攻略分享等功能的综合性系统。该系统融合…...
【Node.js入门笔记1---初始Node.js)】
Node.js入门笔记1 初始Node.js1.Node.js简介2.Node.js中js的运行环境3.Node.js 可以做什么4.Node.js 怎么学 初始Node.js 1.Node.js简介 Node.js 是一个基于 Chrome V8 引擎 的 JavaScript 运行时环境,用于在服务器端运行 JavaScript 代码。它让开发者可以用 Java…...
自学Java-JavaSE基础加强(多线程)
自学Java-JavaSE基础加强(多线程) 一、创建线程1、方式一:继承Thread类小结 2、方式二:实现Runnable接口小结 3、方式三:实现Callable接口4、小结 二、线程的常用方法三、线程安全1、认识线程安全2、模拟线程安全问题3…...
数字后端培训实战项目六大典型后端实现案例
Q1:请教一个问题,cts.sdc和func.sdc在innovus用如何切换?在flow哪一步切换输入cts.sdc?哪一步切换到func.sdc,具体如何操作? 这个学员其实就是在问使用分段长clock tree时具体的flow流程是怎么样的?针对时…...
安卓免费多功能工具:一站式解决 PDF 阅读、编辑、转换等需求
软件介绍 今天要给大家介绍一款功能强大的PDF处理软件——PDFgear Android版。它是专为安卓设备打造的,完全免费,无需破解和激活就能使用。 此前,我们分享过它的桌面端,收获了大家的一致好评。今天要着重介绍的手机APP版本&…...
diffuser库使用本地模型生成图像
实验目的 使用diffuser库生成图像的文章是很多的,使用方法也并不复杂,安装库后调用现成的模型和接口即可,但是因为网络原因,模型下载总会遇到问题,对于使用服务器的研究者来说,挂梯子并不可行,…...
递归—基础算法
#基线条件和递归条件 #每个递归函数都有两部分:基线条件和递归条件。递归条件指的是函数调用自己,而基线条件则指的是函数不再调用自己,从而避免形成无限循环。 #栈:栈是一种数据结构,它是一种线性数据结构,…...
【kafka】Golang实现分布式Masscan任务调度系统
要求: 输出两个程序,一个命令行程序(命令行参数用flag)和一个服务端程序。 命令行程序支持通过命令行参数配置下发IP或IP段、端口、扫描带宽,然后将消息推送到kafka里面。 服务端程序: 从kafka消费者接收…...
Java 8 Stream API 入门到实践详解
一、告别 for 循环! 传统痛点: Java 8 之前,集合操作离不开冗长的 for 循环和匿名类。例如,过滤列表中的偶数: List<Integer> list Arrays.asList(1, 2, 3, 4, 5); List<Integer> evens new ArrayList…...
基于服务器使用 apt 安装、配置 Nginx
🧾 一、查看可安装的 Nginx 版本 首先,你可以运行以下命令查看可用版本: apt-cache madison nginx-core输出示例: nginx-core | 1.18.0-6ubuntu14.6 | http://archive.ubuntu.com/ubuntu focal-updates/main amd64 Packages ng…...
电脑插入多块移动硬盘后经常出现卡顿和蓝屏
当电脑在插入多块移动硬盘后频繁出现卡顿和蓝屏问题时,可能涉及硬件资源冲突、驱动兼容性、供电不足或系统设置等多方面原因。以下是逐步排查和解决方案: 1. 检查电源供电问题 问题原因:多块移动硬盘同时运行可能导致USB接口供电不足&#x…...
AI编程--插件对比分析:CodeRider、GitHub Copilot及其他
AI编程插件对比分析:CodeRider、GitHub Copilot及其他 随着人工智能技术的快速发展,AI编程插件已成为提升开发者生产力的重要工具。CodeRider和GitHub Copilot作为市场上的领先者,分别以其独特的特性和生态系统吸引了大量开发者。本文将从功…...
Java多线程实现之Thread类深度解析
Java多线程实现之Thread类深度解析 一、多线程基础概念1.1 什么是线程1.2 多线程的优势1.3 Java多线程模型 二、Thread类的基本结构与构造函数2.1 Thread类的继承关系2.2 构造函数 三、创建和启动线程3.1 继承Thread类创建线程3.2 实现Runnable接口创建线程 四、Thread类的核心…...
三分算法与DeepSeek辅助证明是单峰函数
前置 单峰函数有唯一的最大值,最大值左侧的数值严格单调递增,最大值右侧的数值严格单调递减。 单谷函数有唯一的最小值,最小值左侧的数值严格单调递减,最小值右侧的数值严格单调递增。 三分的本质 三分和二分一样都是通过不断缩…...
Spring Security 认证流程——补充
一、认证流程概述 Spring Security 的认证流程基于 过滤器链(Filter Chain),核心组件包括 UsernamePasswordAuthenticationFilter、AuthenticationManager、UserDetailsService 等。整个流程可分为以下步骤: 用户提交登录请求拦…...
华为OD最新机试真题-数组组成的最小数字-OD统一考试(B卷)
题目描述 给定一个整型数组,请从该数组中选择3个元素 组成最小数字并输出 (如果数组长度小于3,则选择数组中所有元素来组成最小数字)。 输入描述 行用半角逗号分割的字符串记录的整型数组,0<数组长度<= 100,0<整数的取值范围<= 10000。 输出描述 由3个元素组成…...
实战设计模式之模板方法模式
概述 模板方法模式定义了一个操作中的算法骨架,并将某些步骤延迟到子类中实现。模板方法使得子类可以在不改变算法结构的前提下,重新定义算法中的某些步骤。简单来说,就是在一个方法中定义了要执行的步骤顺序或算法框架,但允许子类…...
