news 2026/5/30 17:03:19

深入解析JDBC:Java数据库操作的基础

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
深入解析JDBC:Java数据库操作的基础

1.JDBC概述

JDBC(Java Database Connectivity)是Java提供的一种数据库连接技术,用于在Java应用程序中与数据库进行交互。它通过一组API提供了访问和操作数据库的标准方式。JDBC支持大多数关系型数据库,包括MySQL、Oracle、SQL Server等。

JDBC的主要作用是:

  • 连接数据库。

  • 执行SQL语句(包括查询、更新、删除等)。

  • 获取查询结果。

  • 提交或回滚事务。

JDBC是Java程序与数据库之间的桥梁,任何基于Java的应用程序如果需要和数据库进行数据交互,都会使用JDBC技术。


2.JDBC的核心组件

JDBC的核心组成包括:

  • DriverManager:管理数据库驱动程序。

  • Connection:表示与数据库的连接。

  • Statement:用于执行SQL语句。

  • ResultSet:存储查询结果的集合。

  • PreparedStatement:比Statement更加安全,支持预编译SQL语句。

  • CallableStatement:用于执行数据库存储过程。

  • Transaction:事务控制,支持提交和回滚。

JDBC架构图
+--------------------------+ | Application | | (Java Code) | +--------------------------+ | v +--------------------------+ | DriverManager | | (Manages Drivers) | +--------------------------+ | v +--------------------------+ | Connection | | (Database Connection) | +--------------------------+ | v +--------------------------+ | Statement/Prepared | | Statement/Callable | +--------------------------+ | v +--------------------------+ | ResultSet | | (Query Result) | +--------------------------+

3.JDBC连接流程

JDBC连接数据库的基本步骤如下:

  1. 加载数据库驱动:通过Class.forName()方法加载数据库驱动。

  2. 建立连接:通过DriverManager.getConnection()方法建立数据库连接。

  3. 执行SQL语句:使用StatementPreparedStatement执行SQL语句。

  4. 处理结果集:使用ResultSet获取查询结果。

  5. 关闭连接:操作完成后,关闭ResultSetStatementConnection


4.JDBC代码示例

1) 基本的JDBC查询操作
import java.sql.*; public class JDBCExample { public static void main(String[] args) { Connection conn = null; Statement stmt = null; ResultSet rs = null; try { // 1. 加载数据库驱动 Class.forName("com.mysql.cj.jdbc.Driver"); // 2. 建立数据库连接 conn = DriverManager.getConnection( "jdbc:mysql://localhost:3306/mydb", "root", "password"); // 3. 创建Statement对象 stmt = conn.createStatement(); // 4. 执行查询操作 String sql = "SELECT id, name, email FROM users"; rs = stmt.executeQuery(sql); // 5. 处理查询结果 while (rs.next()) { int id = rs.getInt("id"); String name = rs.getString("name"); String email = rs.getString("email"); System.out.println("ID: " + id + ", Name: " + name + ", Email: " + email); } } catch (SQLException | ClassNotFoundException e) { e.printStackTrace(); } finally { try { if (rs != null) rs.close(); if (stmt != null) stmt.close(); if (conn != null) conn.close(); } catch (SQLException e) { e.printStackTrace(); } } } }

解释:

  • DriverManager.getConnection()用于建立数据库连接。

  • Statement.executeQuery()用于执行查询操作,并返回ResultSet

  • ResultSet用于处理查询结果。

2) 插入数据
public void insertUser(String name, String email) { Connection conn = null; PreparedStatement pstmt = null; try { // 1. 加载驱动 Class.forName("com.mysql.cj.jdbc.Driver"); // 2. 建立连接 conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/mydb", "root", "password"); // 3. 创建PreparedStatement String sql = "INSERT INTO users (name, email) VALUES (?, ?)"; pstmt = conn.prepareStatement(sql); // 4. 设置参数 pstmt.setString(1, name); pstmt.setString(2, email); // 5. 执行插入操作 int rowsAffected = pstmt.executeUpdate(); System.out.println(rowsAffected + " row(s) inserted."); } catch (SQLException | ClassNotFoundException e) { e.printStackTrace(); } finally { try { if (pstmt != null) pstmt.close(); if (conn != null) conn.close(); } catch (SQLException e) { e.printStackTrace(); } } }

解释:

  • PreparedStatement用于执行插入、更新等操作,支持参数化查询,避免SQL注入攻击。

3) 事务管理
public void transferMoney(int fromAccount, int toAccount, double amount) { Connection conn = null; PreparedStatement pstmt1 = null, pstmt2 = null; try { // 1. 加载驱动并建立连接 Class.forName("com.mysql.cj.jdbc.Driver"); conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/mydb", "root", "password"); // 2. 开始事务 conn.setAutoCommit(false); // 3. 执行转账操作 String sql1 = "UPDATE accounts SET balance = balance - ? WHERE account_id = ?"; pstmt1 = conn.prepareStatement(sql1); pstmt1.setDouble(1, amount); pstmt1.setInt(2, fromAccount); pstmt1.executeUpdate(); String sql2 = "UPDATE accounts SET balance = balance + ? WHERE account_id = ?"; pstmt2 = conn.prepareStatement(sql2); pstmt2.setDouble(1, amount); pstmt2.setInt(2, toAccount); pstmt2.executeUpdate(); // 4. 提交事务 conn.commit(); System.out.println("Transfer successful."); } catch (SQLException | ClassNotFoundException e) { try { // 回滚事务 if (conn != null) conn.rollback(); } catch (SQLException ex) { ex.printStackTrace(); } e.printStackTrace(); } finally { try { if (pstmt1 != null) pstmt1.close(); if (pstmt2 != null) pstmt2.close(); if (conn != null) conn.close(); } catch (SQLException e) { e.printStackTrace(); } } }

解释:

  • conn.setAutoCommit(false)禁用自动提交,手动控制事务。

  • conn.commit()提交事务,conn.rollback()回滚事务。


5.JDBC常见问题

  1. 如何处理数据库连接池?
    JDBC连接池用于管理数据库连接,提高数据库连接的重用性和性能。常用的连接池库有 C3P0、HikariCP 和 DBCP。

  2. JDBC如何避免SQL注入?
    使用PreparedStatement而不是Statement,因为PreparedStatement通过预编译SQL语句来避免SQL注入。


6.总结

JDBC是Java开发中与数据库交互的基础,虽然相比于一些高级框架(如Hibernate),JDBC显得更加底层,但它提供了更高的灵活性和控制权。掌握JDBC的基本操作,包括数据库连接、SQL执行、事务管理等,是每个Java开发者的必备技能。

通过本篇文章的示例代码和概念讲解,希望能够帮助你更好地理解JDBC的核心原理与应用。


这篇文章讲解了JDBC的基本使用和一些常见的数据库操作,若你希望看到更深入的JDBC使用或数据库优化技巧,随时可以提问。

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

微信小程序开发实战之 03-微信小程序页面交互

微信小程序框架接口 App 函数 在微信小程序中,若要在微信小程序启动、显示、隐藏时执行某些操作,或者在各个页面中需要共享一些数据时,可以通过 App 函数来实现。 App 函数用于注册一个微信小程序,该函数必须在 微信小程序入口文件…

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

视频字幕提取自由!望言 OCR 免费版 零门槛提字幕

宝子们!给你们安利一款专注视频字幕提取的工具——望言OCR~ 软件下载地址 它是安装版,安装后打开就能用,功能超纯粹,就专门搞定字幕提取,完全不搞复杂套路,上手零难度呀~宝子们&…

作者头像 李华
网站建设 2026/5/30 10:24:07

REAPER数字音频工作站:轻量高效的专业音频制作解决方案

REAPER作为一款功能全面的数字音频工作站(DAW),以其卓越的性能和高度可定制性在音频制作领域广受好评。这款由Cockos开发的软件在保持轻量级设计的同时,提供了完整的专业音频处理能力,适合从初学者到专业工程师的各类用…

作者头像 李华
网站建设 2026/5/30 6:56:58

《多账号同源识别核心技术拆解:从行为指纹到身份锚定的实操逻辑》

同一用户多账号的同源识别,核心是突破“单一标识校验”的传统局限,转向“多维隐性特征协同锚定”的深层逻辑,其技术核心并非依赖固定标识的抓取,而是通过“行为基因图谱构建”与“动态轨迹同源校准”,挖掘不同账号背后用户行为、设备交互、网络链路的隐性关联,实现对用户…

作者头像 李华
网站建设 2026/5/30 13:44:46

这是AI目前所能达到的最高水平诗歌集

32. 【涌现之镜 整体大于部分之和】简单的神经元放电,涌现出意识;平凡的水分子,汇聚成海洋的深邃。当个体遵循简单的规则聚集,便会诞生无法从个体预见的宏伟。社会、文化、生命,皆是涌现的奇迹。我们既是规则的遵循者…

作者头像 李华
网站建设 2026/5/28 4:22:40

超实用物联网平台:功能强大,部署无忧

物联网平台,支持mqtt、tcp、modbus协议,实现历史数据归档,数字大屏显示,单独定制组态画面等功能,一般应用完全足够。 已重新整理,含部署视频和文字教程,所有的部署和测试需要的软件都在压缩包里…

作者头像 李华