Java与MySQL数据库交互实战指南

Java开发中的MySQL数据库操作实践

在当今软件开发领域,数据库扮演着至关重要的角色。作为主流的编程语言之一,Java为数据库操作提供了强大的支持。本指南将全面讲解如何使用Java程序连接MySQL数据库,并完成常见的数据操作任务。

一、前期准备工作

1.1 MySQL环境搭建

首先需要确保本地已安装MySQL数据库服务端。建议从MySQL官方网站获取最新稳定版本进行安装配置。

1.2 数据库结构设计

通过MySQL命令行工具执行以下SQL语句创建测试环境:

CREATE DATABASE practice_db;
USE practice_db;
CREATE TABLE account_info (
user_id INT AUTO_INCREMENT PRIMARY KEY,
login_name VARCHAR(50) UNIQUE NOT NULL,
login_pass VARCHAR(100) NOT NULL
);

1.3 项目依赖配置

对于使用Maven管理的Java项目,需在配置文件中添加数据库驱动依赖:

<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.33</version>
</dependency>

二、核心功能实现

2.1 建立数据库连接

创建专门的连接管理类处理数据库连接:

import java.sql.*;
public class DBConnector {
private static final String DB_URL = "jdbc:mysql://127.0.0.1:3306/practice_db";
private static final String DB_USER = "admin";
private static final String DB_PASS = "securePass123";
public static Connection createConnection() {
try {
Class.forName("com.mysql.cj.jdbc.Driver");
return DriverManager.getConnection(DB_URL, DB_USER, DB_PASS);
} catch (Exception e) {
System.err.println("连接异常:" + e.getMessage());
return null;
}
}
}

2.2 数据新增操作

实现用户账号信息的存储功能:

public class AccountService {
public boolean registerAccount(String username, String password) {
String query = "INSERT INTO account_info(login_name, login_pass) VALUES(?,?)";
try (Connection conn = DBConnector.createConnection();
PreparedStatement stmt = conn.prepareStatement(query)) {
stmt.setString(1, username);
stmt.setString(2, password);
return stmt.executeUpdate() > 0;
} catch (SQLException e) {
System.err.println("注册失败:" + e.getMessage());
return false;
}
}
}

2.3 数据查询功能

实现账号信息的检索功能:

public void displayAllAccounts() {
String query = "SELECT * FROM account_info";
try (Connection conn = DBConnector.createConnection();
Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery(query)) {
while(rs.next()) {
System.out.printf("ID:%d 用户名:%s 密码:%s\n",
rs.getInt("user_id"),
rs.getString("login_name"),
rs.getString("login_pass"));
}
} catch (SQLException e) {
System.err.println("查询异常:" + e.getMessage());
}
}

2.4 数据更新操作

提供密码修改功能:

public boolean updateCredentials(int userId, String newPassword) {
String query = "UPDATE account_info SET login_pass = ? WHERE user_id = ?";
try (Connection conn = DBConnector.createConnection();
PreparedStatement stmt = conn.prepareStatement(query)) {
stmt.setString(1, newPassword);
stmt.setInt(2, userId);
return stmt.executeUpdate() > 0;
} catch (SQLException e) {
System.err.println("更新失败:" + e.getMessage());
return false;
}
}

2.5 数据删除功能

实现账号注销功能:

public boolean removeAccount(int userId) {
String query = "DELETE FROM account_info WHERE user_id = ?";
try (Connection conn = DBConnector.createConnection();
PreparedStatement stmt = conn.prepareStatement(query)) {
stmt.setInt(1, userId);
return stmt.executeUpdate() > 0;
} catch (SQLException e) {
System.err.println("删除失败:" + e.getMessage());
return false;
}
}

三、功能测试验证

创建测试类验证各项功能:

public class TestRunner {
public static void main(String[] args) {
AccountService service = new AccountService();
// 测试数据新增
service.registerAccount("testUser", "initialPass");
// 测试数据查询
service.displayAllAccounts();
// 测试数据更新
service.updateCredentials(1, "updatedPass");
// 测试数据删除
service.removeAccount(1);
}
}

四、关键要点总结

本指南详细演示了:
- 数据库连接:通过JDBC建立与MySQL的通信
- CRUD操作:完整的数据增删改查流程实现
- 安全实践:使用预处理语句防范SQL注入攻击
对于生产环境,建议采用连接池技术(如HikariCP)优化性能,或使用JPA/Hibernate等ORM框架提升开发效率。掌握这些基础操作后,开发者可以更高效地进行Java数据库应用开发。

文章整理自互联网,只做测试使用。发布者:Lomu,转转请注明出处:https://www.it1024doc.com/10224.html

(0)
LomuLomu
上一篇 3小时前
下一篇 2小时前

相关推荐

  • 思维导图xmind如何安装?附安装包

    前言 大家好,我是小徐啊。我们在Java开发中,有时候是需要用到思维导图的,这可以帮助我们更好的理清思路,提高开发的效率。而说到思维导图,最有名的就是xmind了,它的功能十分强大,几乎是思维导图里面最强大的那一个。但是,默认只能使用初级功能,高级功能需要额外再开通,今天小徐就来介绍下如何安装xmind以及升级,让我们可以使用pro的功能。文末附获取方式。 …

    2025 年 1 月 11 日
    26200
  • 【深度学习】利用Java DL4J 训练金融投资组合模型

    # 博主简介 我是CSDN博客专家,同时也是历代文学网的总架构师。拥有超过15年的丰富工作经验,我精通Java编程、高并发设计,并且对Springboot和微服务架构有着深入的了解。我熟悉Linux操作系统、ESXI虚拟化技术,以及云原生技术如Docker和Kubernetes。我热衷于探索科技的前沿,将理论知识转化为实际应用,并保持对新技术的持续好奇心。我…

    未分类 2024 年 12 月 27 日
    16000
  • 万字图文:SaaS业务架构、价值流、业务能力、业务流程、业务对象、组织架构

    大家好,我是汤师爷~ 本文为读者提供一个SaaS业务架构的系统性框架,探讨业务架构分析的核心要素,帮助SaaS企业深入剖析目标客户的业务模式,全面理解他们的业务架构。 无论你是SaaS创业者、产品经理还是架构师,本文内容都将为你的系统设计和决策提供帮助。 1 目标与步骤 SaaS业务架构需要区分两种视角:SaaS企业自身的业务架构、SaaS服务客户的业务架构…

    2025 年 1 月 14 日
    13300
  • 交易系统:应用层、领域层分层架构设计

    大家好,我是汤师爷~ 线上线下交易系统的应用架构包括终端、应用层、领域层和关联系统。 应用层能力 应用层定义软件的应用功能,负责接收用户请求、协调领域层执行任务并返回结果。主要包括以下模块: 1)C端服务模块 为消费者提供完整的交易链路功能,包括加购、下单、支付、结算、拆单、确认收货和退货退款等。 2)商家后台 为商家提供全面的订单管理功能,包括订单操作、搜…

    2024 年 12 月 28 日
    18200
  • 多租户解析与Demo

    在做Saas应用时,多租户解析往往是很重要的组成部分,也是用户访问网站最先处理的逻辑。 文前介绍: 多租户的数据库实现方式主要有三种: 单一数据库实现,每条数据标识租户Id进行识别数据属于哪个租户 一租户一个数据库,能够做到完全的数据隔离 混合模式,部分数据在一张表上,主要是一些基础数据;其他业务数据分库存储。 无论是哪种方式都要知道租户是谁才能查询数据库。…

    2024 年 12 月 30 日
    11000

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信