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 的架构分为两层:

  1. 应用程序层:开发者编写的 Java 代码。
  2. 驱动层:数据库厂商提供的 JDBC 驱动(如 mysql-connector-java)。

核心接口与类

组件作用
DriverManager管理数据库驱动,建立与数据库的连接
Connection表示与数据库的会话,用于管理事务和创建语句对象
Statement执行静态 SQL 语句(如 SELECT, INSERT
PreparedStatement预编译 SQL 语句,防止 SQL 注入,提升性能
CallableStatement调用数据库存储过程
ResultSet封装查询结果集,支持遍历和读取数据

三、JDBC 工作流程详解

6 步完成数据库操作

注册驱动
建立连接
创建Statement
执行SQL
处理结果
关闭资源
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

根据需求选择 StatementPreparedStatement

// 静态 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:为什么前者更优秀?

对比项StatementPreparedStatement
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 操作数据库的标准,通过驱动实现跨数据库兼容。
  • PreparedStatementStatement 更安全高效。
  • 事务和连接池是提升性能与稳定性的关键。

掌握 JDBC,您已打通 Java 与数据库的桥梁! 🚀

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/982318.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

最硬核DNS详解

1、是什么 DNS&#xff08;域名系统&#xff09;是互联网的一项服务&#xff0c;它作为将域名和IP地址相互映射的一个分布式数据库&#xff0c;能够使人更方便地访问互联网。DNS协议基于UDP协议&#xff0c;使用端口号53。 2、域名服务器类型 域名服务器在DNS体系中扮演着不…

CentOS 7 安装Nginx-1.26.3

无论安装啥工具、首先认准了就是官网。Nginx Nginx官网下载安装包 Windows下载&#xff1a; http://nginx.org/download/nginx-1.26.3.zipLinxu下载 wget http://nginx.org/download/nginx-1.26.3.tar.gzLinux安装Nginx-1.26.3 安装之前先安装Nginx依赖包、自行选择 yum -y i…

基于国产芯片的AI引擎技术,打造更安全的算力生态 | 京东零售技术实践

近年来&#xff0c;随着国产AI芯片的日益崛起&#xff0c;基于国产AI芯片的模型适配、性能优化以及应用落地是国产AI应用的一道重要关卡。如何在复杂的京东零售业务场景下更好地使用国产AI芯片&#xff0c;并保障算力安全&#xff0c;是目前亟需解决的问题。对此&#xff0c;京…

osg官方例子

osg3.6.5官方例子 osganimate osganimationeasemotion osganimationmakepath osganimationmorph

分享react后台管理系统常见的组件/知识点

前言 虽然各个前端框架的常用组件库已经非常完善&#xff0c;但做具体业务时&#xff0c;一般情况下&#xff0c;我们无法直接套用组件&#xff0c;需要自己进行撰写对应业务逻辑。 这篇文章总结做react表单列表常见的组件/知识点。 注意&#xff1a;本篇仅提供相关功能的核心…

自动驾驶---不依赖地图的大模型轨迹预测

1 前言 早期传统自动驾驶方案通常依赖高精地图&#xff08;HD Map&#xff09;提供道路结构、车道线、交通规则等信息&#xff0c;可参考博客《自动驾驶---方案从有图迈进无图》&#xff0c;本质上还是存在问题&#xff1a; 数据依赖性高&#xff1a;地图构建成本昂贵&#xf…

如何在您的 QQ机器人 中集成 码本 AI 模型!

如何在您的QQ机器人中集成 码本 AI 模型&#xff01; 开源技术栏 通过使用此工具&#xff0c;您可以轻松地将 码本 API 服务 集成到您的 QQ 机器人 中&#xff0c;实现快速部署和运行。 这个工具专为简化复杂流程设计&#xff0c;即便是初学者也能轻松上手&#xff0c;让您的…

Java与数据库

目录 一.本文焦点&#xff1a; 二.数据库常用数据类型 三.对数据库操作 四.对数据库中的表操作 五.条件表达 六. 表查询操作进阶 1.多表连接查询 1&#xff09;交叉连接查询 2&#xff09;内连接&#xff08;取两表交集&#xff09; 3&#xff09;外连接 4&#xff09…

基于ANTLR4的大数据SQL编辑器解析引擎实践|得物技术

一、背景 随着得物离线业务的快速增长&#xff0c;为了脱离全托管服务的一些限制和享受技术发展带来的成本优化&#xff0c;公司提出了大数据Galaxy开源演进项目&#xff0c;将离线业务从全托管且封闭的环境迁移到一个开源且自主可控的生态系统中&#xff0c;而离线开发治理套…

HTML第四节

一.复合选择器 1.后代选择器 注&#xff1a;1.后代选择器会选中后代所有的要选择的标签 2.儿子选择器 3.并集选择器 注&#xff1a;1.注意换行&#xff0c;同时选中多种标签 4.交集选择器 注&#xff1a;1.标签选择器放在最前面&#xff0c;例如放在类选择器的前面 2.两个选择…

数字后端培训实战项目六大典型后端实现案例

Q1:请教一个问题&#xff0c;cts.sdc和func.sdc在innovus用如何切换&#xff1f;在flow哪一步切换输入cts.sdc&#xff1f;哪一步切换到func.sdc&#xff0c;具体如何操作&#xff1f; 这个学员其实就是在问使用分段长clock tree时具体的flow流程是怎么样的&#xff1f;针对时…

linux 使用阿里云盘 阿里网盘

可参考&#xff1a;https://blog.csdn.net/qq_41174671/article/details/127310715 一、对文件<100M的可以使用如下方法&#xff1a; 1.临时使用阿里网盘 wget https://github.com/tickstep/aliyunpan/releases/download/v0.2.7/aliyunpan-v0.2.7-linux-amd64.zip unzip …

性能测试--大厂面试问题解析

性能测试作为软件开发中的关键环节&#xff0c;确保系统在高负载下仍能高效运行。面试中&#xff0c;相关问题常被问及&#xff0c;包括定义、类型、工具选择、规划与执行方法、常见瓶颈、敏捷环境下的处理、监控作用、虚拟用户数量确定、功能测试的区别、JMeter工作原理、HTTP…

hom_mat2d_to_affine_par 的c#实现

hom_mat2d_to_affine_par 的c#实现 背景&#xff1a;为课室贡献一个通用函数&#xff0c;实现halcon算子的同等效果&#xff0c;查询csdn未果&#xff0c;deepseek二哥与chtgpt大哥给不了最终程序&#xff0c;在大哥与二哥帮助下&#xff0c;最终实现同等效果。 踩坑&#xf…

前端跨域设置 withCredentials: true

在做登录认证的时候&#xff0c;会出现请求未登录的情况&#xff0c;查看请求头的时候发现并没有把登录时的cookie设置到第二次的请求头里面。查看资料才知道跨域请求要想带上cookie&#xff0c;必须要在ajax请求里加上 withCredentials: true 再次访问发现请求头可以携带cook…

【漫话机器学习系列】122.相关系数(Correlation Coefficient)

深入理解相关系数&#xff08;Correlation Coefficient&#xff09; 1. 引言 在数据分析、统计学和机器学习领域&#xff0c;研究变量之间的关系是至关重要的任务。我们常常想知道&#xff1a;当一个变量变化时&#xff0c;另一个变量是否也会随之变化&#xff1f;如果会&…

uniapp+微信小程序+地图+传入多个标记点显示+点击打开内置地图导航+完整代码

一、效果展示 二、完整代码 <template><view class"container"><map class"map-container" :latitude"latitude" :longitude"longitude" :markers"markers" :controls"controls" show-location m…

高效数据管理:WPF中实现带全选功能的DataGrid复选框列

目录 引言项目结构与准备工作XAML布局设计后台代码实现视图模型设计总结引言 在许多应用场景中,我们需要在表格中选择多行数据进行批量操作,如删除、导出等。为了提高用户体验,通常会在表格的第一列添加一个复选框,允许用户逐个或批量选择数据项。本文将详细介绍如何在 WP…

一周学会Flask3 Python Web开发-SQLAlchemy简介及安装

锋哥原创的Flask3 Python Web开发 Flask3视频教程&#xff1a; 2025版 Flask3 Python web开发 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili SQLAlchemy是Python编程语言下的一款开源软件。提供了SQL工具包及对象关系映射&#xff08;ORM&#xff09;工具&#xff0c;…

《Linux C 智能 IO 矩阵:输入输出的自适应数据流转》

1. 标准库IO简介 标准库IO特点&#xff1a;通过操作系统提供的接口&#xff08;API&#xff09;和操作系统进行交互。&#xff08;接近100个函数&#xff09; 1.1. IO的过程 操作系统&#xff1a;向上为用户提供操作接口&#xff0c;向下为统筹控制硬件。 操作系统的组成&#…