【JavaSE专栏90】用最简单的方法,使用 JDBC 连接 MySQL 数据库

news2025/1/23 14:58:19

作者主页:Designer 小郑
作者简介:3年JAVA全栈开发经验,专注JAVA技术、系统定制、远程指导,致力于企业数字化转型,CSDN学院、蓝桥云课认证讲师。
主打方向:Vue、SpringBoot、微信小程序

本文讲解了如何使用 JDBC 连接 MySQL 数据库,并给出了样例代码。JDBC 是 Java 语言访问关系型数据库的一种标准 API,它提供了一组用于在 Java 程序中与数据库进行交互的接口和类。

目录

  • 一、什么是 JDBC
  • 二、什么是 MySQL
  • 三、JDBC 连接 MySQL
  • 四、JDBC的应用场景
  • 五、JDBC 连接MySQL 面试题
  • 六、总结

在这里插入图片描述


一、什么是 JDBC

JDBC 是 Java 语言访问关系型数据库的一种标准 API,它提供了一组用于在 Java 程序中与数据库进行交互的接口和类。

通过 JDBC,开发人员可以使用 Java 语言编写代码,连接到数据库服务器、执行 SQL 语句、处理查询结果和事务等。

JDBC的主要特点包括以下 4 4 4 点,请同学们认真学习。

  1. 简单易用:JDBC 提供了一组直观的接口和类,使开发人员能够方便地连接数据库、发送 SQL 语句和处理结果。
  2. 广泛支持:JDBC 可以与各种关系型数据库进行交互,如 Oracle、MySQL、SQL Server、PostgreSQL等。
  3. 独立性:JDBC 是基于 Java 标准的 API,可以在不同的平台上使用,不受特定数据库厂商的限制。
  4. 安全性:JDBC 提供了对数据库连接的安全管理,可以对连接进行认证和授权。

使用 JDBC 的基本步骤包括,请同学们尝试使用 JDBC。

  1. 加载数据库驱动程序:使用 Class.forName() 方法加载 JDBC 驱动程序,将其注册到 JVM 中。
  2. 建立数据库连接:使用 DriverManager.getConnection() 方法建立与数据库服务器的连接,并提供连接 URL、用户名和密码等参数。
  3. 创建 StatementPreparedStatement 对象:使用连接对象的 createStatement()prepareStatement() 方法创建用于执行 SQL 语句的对象。
  4. 执行 SQL 语句:使用 StatementPreparedStatement 对象的 executeQuery()executeUpdate() 等方法执行 SQL 语句。
  5. 处理查询结果:对于查询语句,使用ResultSet对象获取查询结果,并对结果进行处理。
  6. 关闭资源:在使用完 JDBC 对象后,需要显式地关闭连接、Statement、ResultSet 等资源,以释放数据库和 JDBC 资源。

JDBC 提供了一种灵活且强大的方式来在 Java 程序中与数据库进行交互,使开发人员能够轻松地操作和管理数据库。

在这里插入图片描述


二、什么是 MySQL

MySQL 是一种开源的关系型数据库管理系统,MySQL 广泛应用于各种规模的应用程序和网站中,包括企业级应用和个人网站,MySQL 具有以下 8 8 8 个特点,请同学们认真学习。

  1. 开源性:MySQL 是免费提供的开源软件,用户可以自由使用、修改和分发。
  2. 可靠性:MySQL 经过广泛测试和验证,具有高度可靠性和稳定性,能够处理大规模数据和高并发访问。
  3. 跨平台性:MySQL 支持多个操作系统,包括 Windows、Linux、macOS 等,可以在不同平台上运行。
  4. 高性能:MySQL 在设计上注重性能优化,采用了多种技术来提高数据库的响应速度和处理能力。
  5. 简单易用:MySQL 提供了简单且直观的命令和工具,使用户可以方便地管理和操作数据库。
  6. 安全性:MySQL 提供了多种安全机制,包括用户认证、权限管理、数据加密等,以保护数据库的安全性。
  7. 扩展性:MySQL 支持水平和垂直扩展,可以通过集群架构和分区技术来处理大规模数据和高并发访问。
  8. 丰富的功能:MySQL 提供了丰富的功能和特性,包括事务处理、索引优化、存储过程、触发器、视图等。

MySQL 使用标准的 SQL 语言进行数据库的操作和查询,具有良好的兼容性,并且支持多种编程语言的接口和 API,如 Java、Python、PHP 等。由于其开源、可靠和高性能的特点,MySQL 成为了最受欢迎的关系型数据库之一,被广泛应用于各种 Web 应用、企业级系统和云平台中。

在这里插入图片描述


三、JDBC 连接 MySQL

以下是一个简单的 Java 样例代码,用于连接 MySQL 数据库并执行查询操作,请同学们复制到本地执行。

说明:以下代码仅为本地数据的测试连接数据,不包含真实项目的密匙、口令!

import java.sql.*;

public class JDBCExample {
    public static void main(String[] args) {
        // JDBC连接信息
        String url = "jdbc:mysql://localhost:3306/demo"; // 数据库连接URL
        String username = "root"; // 数据库用户名
        String password = "123456"; // 数据库密码

        Connection conn = null;
        Statement stmt = null;
        ResultSet rs = null;

        try {
            // 加载JDBC驱动程序
            Class.forName("com.mysql.cj.jdbc.Driver");

            // 建立数据库连接
            conn = DriverManager.getConnection(url, username, password);

            // 创建Statement对象,用于执行SQL语句
            stmt = conn.createStatement();

            // 执行SQL查询语句
            String sql = "SELECT * FROM employees";
            rs = stmt.executeQuery(sql);

            // 处理查询结果
            while (rs.next()) {
                int id = rs.getInt("id");
                String name = rs.getString("name");
                double salary = rs.getDouble("salary");

                System.out.println("ID: " + id + ", Name: " + name + ", Salary: " + salary);
            }
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        } catch (SQLException 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();
            }
        }
    }
}

这个例子展示了使用 JDBC 连接 MySQL 数据库并执行查询操作的基本步骤。

首先,我们加载 MySQL 驱动程序,然后建立与数据库的连接。

接下来,我们创建一个 Statement 对象来执行 SQL 查询语句,并通过 executeQuery 方法执行查询操作。

最后,我们通过 ResultSet 对象处理查询结果,并进行相应的操作。

在完成数据库操作后,我们需要关闭连接、Statement 和 ResultSet 等资源。

在这里插入图片描述


四、JDBC的应用场景

JDBC 在 Java 应用程序中有广泛的应用场景,主要包括以下 6 6 6 个方面,请同学们认真学习。

  1. 数据库连接与操作:JDBC 可以用于与关系型数据库进行连接和操作。开发人员可以使用 JDBC API 建立数据库连接、执行 SQL 语句、处理查询结果、事务管理等。
  2. 数据库访问层:JDBC 可以作为 Java 应用程序与数据库之间的中间层,封装数据库操作,提供高层次的接口和方法,方便应用程序开发。这样可以使应用程序与底层数据库相分离,提高了应用程序的可维护性和可移植性。
  3. 数据库迁移和同步:JDBC 可以用于数据库迁移和数据同步的工作。通过 JDBC,可以将数据从一个数据库迁移到另一个数据库,也可以将数据从一个数据源同步到另一个数据源。
  4. 数据库连接池:JDBC 连接池是一种常见的技术,用于管理数据库连接的复用和分配。通过使用连接池,可以提高数据库连接的效率和性能,减少连接的创建和销毁开销。
  5. 数据库报表和分析:JDBC 可以用于从数据库中获取数据,并进行报表生成和数据分析。通过执行查询语句,获取结果集,然后对结果集进行处理和分析,生成报表或进行其他数据分析操作。
  6. 数据库备份和恢复:JDBC 可以用于数据库备份和恢复操作。通过执行数据库备份命令,将数据库的数据和结构保存到文件中;通过执行数据库恢复命令,将备份文件中的数据和结构恢复到数据库中。

总之,JDBC 的应用场景非常广泛,几乎所有需要与关系型数据库进行交互的 Java 应用程序都可以使用 JDBC 来实现。

无论是简单的数据查询,还是复杂的事务处理,JDBC 都能提供灵活且强大的功能来满足开发人员的需求。

在这里插入图片描述


五、JDBC 连接MySQL 面试题

一、如何在 Java 中使用 JDBC 连接 MySQL 数据库?

答:要使用JDBC连接MySQL数据库,首先需要导入MySQL的JDBC驱动程序。然后,通过加载驱动程序、建立数据库连接、执行SQL语句等步骤来连接和操作数据库。

二、JDBC 连接 MySQL 的步骤是什么?

答:连接MySQL数据库的步骤如下:

  • 加载 JDBC 驱动程序:使用 Class.forName() 方法加载 MySQL 的 JDBC 驱动程序。
  • 建立数据库连接:使用 DriverManager.getConnection() 方法建立与 MySQL 数据库的连接。
  • 创建 Statement 对象:使用 Connection.createStatement() 方法创建 Statement 对象,用于执行 SQL 语句。
  • 执行 SQL 语句:使用 Statement 对象的 executeQuery() 方法执行查询语句,或者使用 executeUpdate() 方法执行更新语句。
  • 处理结果集:使用 ResultSet 对象来处理查询结果。
  • 关闭连接和资源:在完成数据库操作后,需要关闭连接、Statement 和 ResultSet 等资源。

三、如何处理 JDBC 连接 MySQL 时的异常?

答:在使用 JDBC 连接 MySQL 时,可能会遇到各种异常情况,如数据库连接失败、SQL 语句执行错误等。可以通过 try-catch 语句块来捕获异常,并在 catch 块中处理异常情况,如打印错误信息、回滚事务等。

四、如何使用连接池管理 JDBC 连接 MySQL?

答:使用连接池可以提高数据库连接的效率和性能。常见的连接池实现包括 Apache Commons DBCP、C3P0、HikariCP 等。可以通过配置连接池的参数,如最大连接数、最小空闲连接数等,来管理连接池中的连接。通过从连接池中获取连接、执行 SQL 语句、释放连接等操作,实现 JDBC 连接 MySQL 的连接池管理。

五、如何处理 JDBC 连接 MySQL 时的事务?

答:可以通过设置连接的事务隔离级别、使用 setAutoCommit(false) 方法关闭自动提交,以及使用 commit()rollback() 方法来管理事务。通过在 try-catch 块中进行事务处理,可以在发生异常时回滚事务,保持数据的一致性。


六、总结

本文讲解了如何使用 JDBC 连接 MySQL 数据库,并给出了样例代码,在最后一篇博客中,将讲解如何使用 Java 发起 Http 请求,从而实现与三方网站的整合。

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

git-tf clone 路径有空格处理方案

git-tf clone 路径存在空格情况下,运行命令报错; 需要对路径进行双引号处理

汽车电子笔记之:基于AUTOSAR的电机控制器架构设计

目录 1、概述 2、AUTOSAR设计 2.1、SWC设计 2.2、PORT设计 2.3、Runnable设计 2.4、电机控制器OS实现 1、概述 电机控制器应用层的软件架构较为复杂,主要包括PMSM(Permanent-MagnetSynchronous Motor)的矢量控制算法。根据PMSM的控制算法,对算法中的软件功能进行分析&…

Linux 多线程同步机制(上)

文章目录 前言一、线程同步二、互斥量 mutex三、死锁总结 前言 一、线程同步 在多线程环境下,多个线程可以并发地执行,访问共享资源(如内存变量、文件、网络连接 等)。 这可能导致 数据不一致性, 死锁, 竞争条件等 问题。 为了解…

【LeetCode-中等题】138. 复制带随机指针的链表

文章目录 题目解题核心思路:找random指针指向思路一:哈希思路二:迭代构造新链表 方法一:哈希递归方法二:纯哈希方法三:迭代 节点拆分 题目 解题核心思路:找random指针指向 这里的拷贝属于深拷…

Leetcode刷题:395. 至少有 K 个重复字符的最长子串、823. 带因子的二叉树

Leetcode刷题:395. 至少有 K 个重复字符的最长子串、823. 带因子的二叉树 1. 395. 至少有 K 个重复字符的最长子串算法思路参考代码和运行结果 2. 823. 带因子的二叉树算法思路参考代码和运行结果 1. 395. 至少有 K 个重复字符的最长子串 题目难度:中等 标签&#…

lenovo联想笔记本小新Air-15 2021款Intel版ITL版(82GM)原装出厂Win10系统

自带所有驱动、出厂主题壁纸LOGO、Office办公软件、联想电脑管家等预装程序 所需要工具:16G或以上的U盘 文件格式:ISO 文件大小:11.2GB 链接:https://pan.baidu.com/s/12NTMOt5eUjOIsbayXPyiww?pwdrs4v 提取码&#xf…

基于单片机的数字温度计设计

一、项目背景 数字温度计是一种用于测量和显示环境温度的设备。本文章介绍基于STC89C52主控芯片的数字温度计的设计过程和实现原理。该设计采用DS18B20温度传感器进行温度采集,使用LCD1602显示屏进行温度显示,通过按键设置温度的上限和下限阀值&#xf…

点云配准算法之NDT

1 前言 很久之前记录了一篇博客PCL点云配准_thequitesunshine007的博客-CSDN博客 ,记录的是基于点特征(FPFH特征描述子)匹配的SAC-ICP点云配准思想。 今天记录一下完全不一样的点云配准方法NDT。 2 介绍 2.1 多元正态分布 如果随机变量X满…

Servlet与Web容器的初探

Servlet 是用Java编写的服务端程序,具有独立于平台和协议的特性,主要功能在于交互式地浏览和生成数据,生成动态Web内容。 Servlet也需要帮助。请求到来时,必须有人实例化Servlet,或者至少要建立一个新的线程处理这个请…

js 正则表达式 验证 :页面中一个输入框,可输入1个或多个vid/pid,使用英文逗号隔开...

就是意思一个输入框里面&#xff0c;按VID/PID格式输入,VID和PID最大长度是4,最多50组 1、页面代码 <el-form ref"ruleForm" :model"tempSet" :rules"rules" label-position"right"> <!-- 最多 50组&#xff0c;每组9个字符…

RT_Thread内核机制学习(三)进程间通信

队列 队列里有多个消息块&#xff0c;每个消息块大小一致。 写&#xff1a; 有空间&#xff0c;成功。无空间&#xff1a;返回Err&#xff1b;等待一段时间。 队列里面会有两个链表&#xff1a;发送链表和接收链表 struct rt_messagequeue {struct rt_ipc_object parent; …

ChatGPT Prompting开发实战(二)

一、基于LangChain源码react来解析prompt engineering 在LangChain源码中一个特别重要的部分就是react&#xff0c;它的基本概念是&#xff0c;LLM在推理时会产生很多中间步骤而不是直接产生结果&#xff0c;这些中间步骤可以被用来与外界进行交互&#xff0c;然后产生new con…

C#,数值计算——双指数DE (double exponential)结构的计算方法与源程序

1 文本格式 using System; namespace Legalsoft.Truffer { /// <summary> /// Structure for implementing the DE (double exponential) rule. /// </summary> public class DErule : Quadrature { private double a { get; set; …

基于SpringBoot的员工(人事)管理系统

基于SpringBoot的员工&#xff08;人事&#xff09;管理系统 一、系统介绍二、功能展示三.其他系统实现五.获取源码 一、系统介绍 项目名称&#xff1a;基于SPringBoot的员工管理系统 项目架构&#xff1a;B/S架构 开发语言&#xff1a;Java语言 前端技术&#xff1a;BootS…

【Spring Cloud系列】- 分布式系统中实现幂等性的几种方式

【Spring Cloud系列】- 分布式系统中实现幂等性的几种方式 文章目录 【Spring Cloud系列】- 分布式系统中实现幂等性的几种方式一、概述二、什么是幂等性三、幂等性需关注几个重点四、幂等性有什么用五、常见用来保证幂等的手段5.1 MVCC方案5.2 去重表5.3 去重表5.4 select in…

5G 数字乡村数字农业农村大数据中心项目农业大数据建设方案PPT

导读&#xff1a;原文《5G 数字乡村数字农业农村大数据中心项目农业大数据建设方案PPT》&#xff08;获取来源见文尾&#xff09;&#xff0c;本文精选其中精华及架构部分&#xff0c;逻辑清晰、内容完整&#xff0c;为快速形成售前方案提供参考。以下是部分内容&#xff0c; 喜…

市级数字政府电子政务大数据中心项目建设和运营方案WORD

导读&#xff1a;原文《市级数字政府电子政务大数据中心项目建设和运营方案WORD》&#xff08;获取来源见文尾&#xff09;&#xff0c;本文精选其中精华及架构部分&#xff0c;逻辑清晰、内容完整&#xff0c;为快速形成售前方案提供参考。以下是部分内容&#xff0c; 目 录 …

5、监测数据采集物联网应用开发步骤(5.1)

监测数据采集物联网应用开发步骤(4) Sqlite3数据库读写操作开发、异常信息统一处理类开发 本章节需要调用sqlite3及mysql-connector 安装sqlite3 Pip3 install sqlite3 安装mysql-connector pip3 install mysql-connector 验证是否安装成功&#xff0c;python中运行下列…

Unity网格编程笔记[十]一些网格基础操作的封装(Mesh合并,UV映射,正反面反转,顶点合并,法线求切线计算等)

这里的代码是在 Unity网格编程笔记[五]网格切割 中整合出来的。 这里的mesh可以直接接入到使用mesh的unity组件 一些基础的属性还是要参考 Unity网格编程笔记[零]网格编程基础知识点 Mesh合并 网格的合并&#xff0c;其实底层也没那么复杂。对于三角面&#xff0c;只是顺序…

LiveGBS伴侣

【1】LiveGBS 简介 LiveGBS是一套支持国标(GB28181)流媒体服务软件。 国标无插件;提供用户管理及Web可视化页面管理&#xff1b; 提供设备状态管理&#xff0c;可实时查看设备是否掉线等信息&#xff1b; 实时流媒体处理&#xff0c;PS&#xff08;TS&#xff09;转ES&…