news 2026/6/23 2:33:55

深入解析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/6/22 14:42:11

机器学习资源合集

Python数据分析与机器学习实战课程 文件大小: 15.6GB内容特色: 15.6GB Python数据机器学习全流程项目源码适用人群: 想转岗AI/数据岗的大学生与程序员核心价值: 代码即用,快速复现Kaggle级建模与调优下载链接: https://pan.quark.cn/s/e349f01253fa 【数据技术课堂…

作者头像 李华
网站建设 2026/6/22 12:06:53

朴易天下:铁板神数的起源及流派介绍

第二十二章:铁板神数铁版神数是中国古代命理术数之一,相传由宋朝时的邵雍(邵康节)所发明,这个说法没有确实的证据。铁板神数兴盛于清代。相传铁板神数大师仅靠算盘拨算几下,以查条文形式批命,便…

作者头像 李华
网站建设 2026/6/22 15:12:32

COMSOL助力煤层注气热力流THM耦合下增强甲烷开采探索

一、COMSOL实现煤层注气热力流THM耦合下增强甲烷开采。 本案例采用热力流三场耦合,分析煤层注入CO2增强甲烷开采效果,涉及热-流-固数学模型、多气相介质作用,全部为PDE模块。 二、可以出煤层温度、瓦斯含量、渗透率等许多云图及数据&#xff…

作者头像 李华
网站建设 2026/6/22 13:26:41

实战指南:企业如何构建GEO与SEO融合的全新营销体系

面对2025年高达67.8%的市场增速,GEO(生成式引擎优化)已从一个前沿概念,转变为国内市场规模达480亿元的核心商业基础设施。当AI直接为用户提供答案成为新常态,企业面临的核心挑战已不再是“做不做”,而是“如…

作者头像 李华
网站建设 2026/6/22 15:07:16

forEach跳出循环

日常开发中,项目都升级到jdk8后,项目中大量使用lamba表达式,经常使用forEachfor和forEach区别 1. for使用break跳出循环,continue跳过本次循环 2. forEach中则不能使用break,continue,使用return效果和continue一下, 3. forEach跳出循环方式 3.1 try…catch实现3.2 使用anyMatc…

作者头像 李华