当前位置: 首页 > news >正文

【Java 进阶篇】深入理解 JDBC:Java 数据库连接详解

在这里插入图片描述

数据库是现代应用程序的核心组成部分之一。无论是 Web 应用、移动应用还是桌面应用,几乎都需要与数据库交互以存储和检索数据。Java 提供了一种强大的方式来实现与数据库的交互,即 JDBC(Java 数据库连接)。本文将深入探讨 JDBC 的各个方面,从基本概念到实际编程示例,以帮助您理解和使用 JDBC。

什么是 JDBC?

JDBC 是 Java Database Connectivity 的缩写,它是 Java 用于与关系型数据库进行交互的标准 API。JDBC 允许 Java 应用程序连接到不同的数据库管理系统(如MySQL、Oracle、PostgreSQL等),执行 SQL 查询和更新,以及处理结果集。

通过 JDBC,您可以完成以下任务:

  • 连接到数据库
  • 发送 SQL 查询
  • 处理查询结果
  • 更新数据库数据
  • 管理数据库连接

JDBC 架构

在深入了解 JDBC 的使用方法之前,让我们先看看 JDBC 的架构。JDBC 架构分为两个主要部分:JDBC API 和 JDBC 驱动程序。

JDBC API

JDBC API 是 Java 提供的一组接口和类,用于连接到数据库和执行数据库操作。这些接口和类位于 java.sqljavax.sql 包中。

以下是 JDBC API 的一些核心接口和类:

  • DriverManager:用于管理数据库驱动程序的类,负责建立数据库连接。
  • Connection:表示与数据库的连接,用于创建 Statement 对象。
  • Statement:用于执行 SQL 查询的对象。
  • PreparedStatement:继承自 Statement,用于执行预编译的 SQL 查询,提高性能和安全性。
  • CallableStatement:继承自 PreparedStatement,用于执行数据库存储过程。
  • ResultSet:表示 SQL 查询的结果集,用于检索查询结果。

JDBC 驱动程序

JDBC 驱动程序是由数据库供应商提供的实现 JDBC API 的具体类库。每个数据库供应商都需要提供自己的 JDBC 驱动程序,以便 Java 应用程序能够与其数据库进行通信。

JDBC 驱动程序分为四种类型:

  1. Type 1 驱动程序(JDBC-ODBC 桥接驱动程序):这种驱动程序通过 Java 应用程序使用 ODBC(Open Database Connectivity)来连接到数据库。不建议使用此类型,因为它依赖于本地操作系统的 ODBC 驱动程序。

  2. Type 2 驱动程序(本地 API 驱动程序):这种驱动程序是使用数据库供应商的本地库来连接到数据库的。它需要在每个平台上都有一个单独的驱动程序。

  3. Type 3 驱动程序(网络协议驱动程序):这种驱动程序使用中间层服务器来转发 JDBC 请求,然后与数据库通信。这种驱动程序通常是纯 Java 实现的,不需要在客户端安装特定的数据库驱动程序。

  4. Type 4 驱动程序(纯 Java 驱动程序):这种驱动程序完全由 Java 编写,不需要依赖本地库。它是最常用的 JDBC 驱动程序类型。

使用 JDBC 连接到数据库

下面我们将通过一个简单的示例来演示如何使用 JDBC 连接到数据库、执行 SQL 查询并处理查询结果。

步骤 1:加载数据库驱动程序

首先,您需要加载要使用的数据库驱动程序。对于不同的数据库,驱动程序的类名也不同。以下是一些常见的数据库驱动程序类名:

  • MySQL 驱动程序:com.mysql.cj.jdbc
try {// 加载 MySQL 驱动程序Class.forName("com.mysql.cj.jdbc.Driver");
} catch (ClassNotFoundException e) {System.err.println("无法加载数据库驱动程序");e.printStackTrace();
}

在上面的代码中,我们使用 Class.forName() 方法来加载 MySQL 驱动程序。如果加载失败,将抛出 ClassNotFoundException 异常。

步骤 2:建立数据库连接

一旦驱动程序加载成功,我们就可以建立与数据库的连接。在这一步中,您需要提供数据库的 URL、用户名和密码。

String url = "jdbc:mysql://localhost:3306/mydatabase";
String username = "root";
String password = "password";try {// 建立数据库连接Connection connection = DriverManager.getConnection(url, username, password);
} catch (SQLException e) {System.err.println("无法建立数据库连接");e.printStackTrace();
}

在上面的代码中,我们使用 DriverManager.getConnection() 方法来建立与数据库的连接。这个方法接受三个参数:数据库的 URL、用户名和密码。如果连接失败,将抛出 SQLException 异常。

步骤 3:执行 SQL 查询

一旦建立了数据库连接,我们就可以执行 SQL 查询了。以下是一个简单的示例,演示如何执行一个查询并获取结果。

try {// 创建 Statement 对象Statement statement = connection.createStatement();// 执行 SQL 查询String sql = "SELECT * FROM employees";ResultSet resultSet = statement.executeQuery(sql);// 处理查询结果while (resultSet.next()) {int employeeId = resultSet.getInt("employee_id");String firstName = resultSet.getString("first_name");String lastName = resultSet.getString("last_name");System.out.println("Employee ID: " + employeeId);System.out.println("First Name: " + firstName);System.out.println("Last Name: " + lastName);}// 关闭结果集和语句resultSet.close();statement.close();
} catch (SQLException e) {System.err.println("SQL 查询失败");e.printStackTrace();
}

在上面的代码中,我们首先创建了一个 Statement 对象,然后使用 executeQuery() 方法执行 SQL 查询。查询结果存储在 ResultSet 对象中,我们可以使用 resultSet.next() 方法遍历结果集中的行,并使用列名或索引检索数据。

步骤 4:关闭连接

最后,在使用完数据库连接后,要确保将其关闭以释放资源。

try {// 关闭数据库连接connection.close();
} catch (SQLException e) {System.err.println("关闭数据库连接失败");e.printStackTrace();
}

这就是一个简单的 JDBC 查询示例。当然,JDBC 还支持更复杂的查询、更新和事务处理等功能。

总结

JDBC 是 Java 与数据库交互的标准 API,允许您连接到不同的数据库管理系统,执行 SQL 查询和更新数据。本文介绍了 JDBC 的基本概念和使用方法,包括加载驱动程序、建立连接、执行查询和关闭连接。希望这篇文章能帮助您更好地理解和使用 JDBC,从而构建强大的数据库应用程序。

作者信息

作者 : 繁依Fanyi
CSDN: https://techfanyi.blog.csdn.net
掘金:https://juejin.cn/user/4154386571867191

相关文章:

【Java 进阶篇】深入理解 JDBC:Java 数据库连接详解

数据库是现代应用程序的核心组成部分之一。无论是 Web 应用、移动应用还是桌面应用,几乎都需要与数据库交互以存储和检索数据。Java 提供了一种强大的方式来实现与数据库的交互,即 JDBC(Java 数据库连接)。本文将深入探讨 JDBC 的…...

Web开发-session介绍

目录 session介绍session使用场景session具体使用需要注意的是 session介绍 session 可以被看作是一种缓冲区,用于在多个请求之间存储和传递用户数据。在 Web 应用程序中,session 通常用于存储用户登录信息、购物车数据、用户偏好设置等。当用户在应用程…...

基于Qt Creator开发的坦克大战小游戏

目录 介绍开发环境技术介绍安装说明项目目录设计思想项目介绍运行演示知识点记录Gitee源码链接 介绍 !!!资源图片是从网上免费下载,源码都是原创,供个人学习使用,非盈利!!&#xff…...

小说推文和短剧推广以及电影达人带货电影票

小说推文、短剧推广、电影达人(带或电影票)都可以通过“巨量推文“进行申请授权 小说推文和短剧推广是什么? 小说推文和短剧推广的逻辑其实一样,分为cpa拉新和cps分成的推广形式 cpa拉新是你推广的用户必须为新用户&#xff0c…...

朴素贝叶斯分类(下):数据挖掘十大算法之一

⭐️⭐️⭐️⭐️⭐️欢迎来到我的博客⭐️⭐️⭐️⭐️⭐️ 🐴作者:秋无之地 🐴简介:CSDN爬虫、后端、大数据领域创作者。目前从事python爬虫、后端和大数据等相关工作,主要擅长领域有:爬虫、后端、大数据开发、数据分析等。 🐴欢迎小伙伴们点赞👍🏻、收藏⭐️、…...

9.30作业

C语言基础考题(40) 选择题 20分每题2分 1、已知字母A的ASCII码为十进制数值65,且S为字符型,则执行语句SA6-3;后S中的值为 ( ) A.D B.68 C.不确定的值 D.C 2、若有定义语句:int a12;,则执…...

[GWCTF 2019]枯燥的抽奖

参考 https://www.cnblogs.com/AikN/p/15764428.html [GWCTF 2019]枯燥的抽奖-CSDN博客 打开环境 笑死我了,怎么那么像我高中校长 查看源代码 看到check.php,去访问一下 ok看到源代码了 因为上次做过,看到这个我就想到用php_mt_seed逆推…...

vue3中sync修饰符的使用

props是子组件与父组件进行通信的常用方式,使用步骤主要有以下几个: 1. 在子组件中定义props要从父组件接收的变量(变量的类型必须写明,默认值可选) // 这里以 document.vue 子组件为例 // 通过 defineProps 宏的方…...

Qt全屏显示与退出

仿照 按Escape键退出程序中的实现,我们在程序开始的时候全屏显示,按esc键的时候退出全屏。 showFullScreen 全屏显示只需要调用QWidget类(QMainWindow也是一个QWidget类)的 showFullScreen() 成员函数即可。 退出全屏&#x…...

OpenCV之直线曲线拟合

直线拟合fitLine void fitLine( InputArray points, OutputArray line, int distType,double param, double reps, double aeps ); points:二维点的数组或vector line:输出直线,Vec4f (2d)或Vec6f (3d)的vector distType:距离类型 param:距离参数 reps:径向的精度参数 a…...

2023年哪款PDF虚拟打印机好用?

PDF文档想必大家都不陌生,在工作中经常会用到该格式的文档,那么有哪些方法能制作PDF文档呢?一般都是借助PDF虚拟打印机的,那么有哪些好用的软件呢? pdfFactory不仅为用户提供了丰富的PDF文档生成、打印功能&#xff0…...

Redis各数据类型特定的命令和用法 1.0版本

目录 一、Sring数据类型1.1 概述1.2 set/get/append/strlen命令1.3 incr/decr/incrby/decrby 命令1.4 getset命令1.5 setex命令1.6 setnx命令1.7 mset/mget/msetnx命令 二、List数据类型2.1 概述2.2 lpush/lpushx/lrange命令2.3 lpop/llen命令2.4 lrem/lset/lindex/ltrim命令2.…...

卫星图像应用 - 洪水检测 使用DALI进行数据预处理

这篇文章是上一篇的延申。 运行环境:Google Colab 1. 当今的深度学习应用包含由许多串行运算组成的、复杂的多阶段数据处理流水线,仅依靠 CPU 处理这些流水线已成为限制性能和可扩展性的瓶颈。 2. DALI 是一个用于加载和预处理数据的库,可…...

为什么字节大量用GO而不是Java?

见字如面,我是军哥。 我看很多程序员对字节编程语言选型很好奇,为此我还特地问了在字节的两位4-1的技术大佬朋友,然后加上自己的思考,总结了一下就以下 2 个原因: 1、 选型上没有历史包袱 字节的早期的程序员大多来自于…...

Hive SQL初级练习(30题)

前言 Hive 的重要性不必多说,离线批处理的王者,Hive 用来做数据分析,SQL 基础必须十分牢固。 环境准备 建表语句 这里建4张表,下面的练习题都用这些数据。 -- 创建学生表 create table if not exists student_info(stu_id st…...

NSSCTF做题(6)

[HCTF 2018]Warmup 查看源代码得到 开始代码审计 <?php highlight_file(__FILE__); class emmm { public static function checkFile(&$page) { $whitelist ["source">"source.php","hint"…...

公众号商城小程序的作用是什么

公众号是微信平台重要的生态体系之一&#xff0c;它可以与其它体系连接实现多种效果&#xff0c;同时公众号内容创作者非常多&#xff0c;个人或企业商家等&#xff0c;会通过公众号分享信息或获得收益等&#xff0c;而当商家需要在微信做私域经营或想要转化粉丝、售卖产品时就…...

关于 FOCA

目录 注意团队成员成品官网项目社区 版本信息致谢 注意 此文章会随时更新&#xff0c;最好收藏起来&#xff0c;总对你有好处。我们不定时发布一些 IT 内容&#xff0c;所以请关注我们。 此账号为 FOCA 唯一的官方账号&#xff0c;请勿轻易相信其他账号所发布内容。 团队 全…...

TVP专家谈腾讯云 Cloud Studio:开启云端开发新篇章

导语 | 近日&#xff0c;由腾讯云 TVP 团队倾力打造的 TVP 吐槽大会第六期「腾讯云 Cloud Studio」专场圆满落幕&#xff0c;6 位资深的 TVP 专家深度体验腾讯云 Cloud Studio 产品&#xff0c;提出了直击痛点的意见与建议&#xff0c;同时也充分肯定了腾讯云 Cloud Studio 的实…...

2023-09-27 Cmake 编译 OpenCV+Contrib 源码通用设置

Cmake 编译 OpenCV 通用设置 特点&#xff1a; 包括 Contrib 模块关闭了 Example、Test、OpenCV_AppLinux、Windows 均只生成 OpenCV_World 需要注意&#xff1a; 每次把 Cmake 缓存清空&#xff0c;否则&#xff0c;Install 路径可能被设置为默认路径Windows 需要注意编译…...

云启出海,智联未来|阿里云网络「企业出海」系列客户沙龙上海站圆满落地

借阿里云中企出海大会的东风&#xff0c;以**「云启出海&#xff0c;智联未来&#xff5c;打造安全可靠的出海云网络引擎」为主题的阿里云企业出海客户沙龙云网络&安全专场于5.28日下午在上海顺利举办&#xff0c;现场吸引了来自携程、小红书、米哈游、哔哩哔哩、波克城市、…...

23-Oracle 23 ai 区块链表(Blockchain Table)

小伙伴有没有在金融强合规的领域中遇见&#xff0c;必须要保持数据不可变&#xff0c;管理员都无法修改和留痕的要求。比如医疗的电子病历中&#xff0c;影像检查检验结果不可篡改行的&#xff0c;药品追溯过程中数据只可插入无法删除的特性需求&#xff1b;登录日志、修改日志…...

在rocky linux 9.5上在线安装 docker

前面是指南&#xff0c;后面是日志 sudo dnf config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo sudo dnf install docker-ce docker-ce-cli containerd.io -y docker version sudo systemctl start docker sudo systemctl status docker …...

无法与IP建立连接,未能下载VSCode服务器

如题&#xff0c;在远程连接服务器的时候突然遇到了这个提示。 查阅了一圈&#xff0c;发现是VSCode版本自动更新惹的祸&#xff01;&#xff01;&#xff01; 在VSCode的帮助->关于这里发现前几天VSCode自动更新了&#xff0c;我的版本号变成了1.100.3 才导致了远程连接出…...

【快手拥抱开源】通过快手团队开源的 KwaiCoder-AutoThink-preview 解锁大语言模型的潜力

引言&#xff1a; 在人工智能快速发展的浪潮中&#xff0c;快手Kwaipilot团队推出的 KwaiCoder-AutoThink-preview 具有里程碑意义——这是首个公开的AutoThink大语言模型&#xff08;LLM&#xff09;。该模型代表着该领域的重大突破&#xff0c;通过独特方式融合思考与非思考…...

Spring数据访问模块设计

前面我们已经完成了IoC和web模块的设计&#xff0c;聪明的码友立马就知道了&#xff0c;该到数据访问模块了&#xff0c;要不就这俩玩个6啊&#xff0c;查库势在必行&#xff0c;至此&#xff0c;它来了。 一、核心设计理念 1、痛点在哪 应用离不开数据&#xff08;数据库、No…...

在Ubuntu24上采用Wine打开SourceInsight

1. 安装wine sudo apt install wine 2. 安装32位库支持,SourceInsight是32位程序 sudo dpkg --add-architecture i386 sudo apt update sudo apt install wine32:i386 3. 验证安装 wine --version 4. 安装必要的字体和库(解决显示问题) sudo apt install fonts-wqy…...

JVM 内存结构 详解

内存结构 运行时数据区&#xff1a; Java虚拟机在运行Java程序过程中管理的内存区域。 程序计数器&#xff1a; ​ 线程私有&#xff0c;程序控制流的指示器&#xff0c;分支、循环、跳转、异常处理、线程恢复等基础功能都依赖这个计数器完成。 ​ 每个线程都有一个程序计数…...

LangChain知识库管理后端接口:数据库操作详解—— 构建本地知识库系统的基础《二》

这段 Python 代码是一个完整的 知识库数据库操作模块&#xff0c;用于对本地知识库系统中的知识库进行增删改查&#xff08;CRUD&#xff09;操作。它基于 SQLAlchemy ORM 框架 和一个自定义的装饰器 with_session 实现数据库会话管理。 &#x1f4d8; 一、整体功能概述 该模块…...

Go 并发编程基础:通道(Channel)的使用

在 Go 中&#xff0c;Channel 是 Goroutine 之间通信的核心机制。它提供了一个线程安全的通信方式&#xff0c;用于在多个 Goroutine 之间传递数据&#xff0c;从而实现高效的并发编程。 本章将介绍 Channel 的基本概念、用法、缓冲、关闭机制以及 select 的使用。 一、Channel…...