Java基础教程(20)-Java连接mysql数据库CURD

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: 【4月更文挑战第19天】MySQL是流行的关系型数据库管理系统,支持SQL语法。在IDEA中加载jar包到项目类路径:右击项目,选择“Open Module Settings”,添加库文件。使用JDBC连接MySQL,首先下载JDBC驱动,然后通过`Class.forName()`加载驱动,`DriverManager.getConnection()`建立连接。执行CRUD操作,例如创建表、插入数据和查询,使用`Statement`或`PreparedStatement`,并确保正确关闭数据库资源。

MYSQL是啥

这个应该不写的,根据文章题目来看,大概率是有所了解的;但是以防万一,简单说一下;

MySQL数据库是一款广泛使用的关系型数据库管理系统(RDBMS),支持标准SQL语法,用户可以使用SQL语句对数据进行操作;

IDEA中如何加载jar包到项目的类路径中

由于java连接mysql需要使用到第三方jar包,所以需要知道如何加载外部jar包到clasapath中;

  • 右击项目或模块,选择“Open Module Settings”

  • 寻找与“Libraries”相关的选项。

  • 添加库文件或目录到依赖列表中。 选择已存在的.jar文件。
    在这里插入图片描述

编码JAVA连接mysql

使用JDBC连接MySQL数据库

  • JDBC:(Java Database Connectivity )

    在Java中连接MySQL数据库通常使用JDBC API,这是Java标准库的一部分,为Java应用程序与mysql数据库的交互提供了统一的接口。

    • 下载MySQL JDBC驱动

      手动下载MySQL JDBC驱动mysql-connector-java-8.0.30.jar并将其添加到项目的类路径中。

  • 加载驱动

    在Java代码中,需要在连接数据库前加载MySQL JDBC驱动。通常使用Class.forName()方法来加载驱动类:

      try {
          
          
        Class.forName("com.mysql.cj.jdbc.Driver");
      } catch (ClassNotFoundException e) {
          
          
        throw new IllegalStateException("MySQL JDBC driver not found", e);
      }
    
  • 创建数据库连接

    使用DriverManager.getConnection()方法创建到MySQL数据库的连接。该方法需要传入数据库连接URL、用户名和密码:

      String url = "jdbc:mysql://localhost:3306/db";
      String username = "username";
      String password = "password";
    
      try (Connection connection = DriverManager.getConnection(url, username, password)) {
         
         
        // 使用数据库连接执行操作...
      }
    
  • 执行CURD操作

    有了数据库连接后,可以创建StatementPreparedStatementCallableStatement对象来执行SQL语句:

    • 建表

      try (Statement statement = connection.createStatement()) {
             
             
            // SQL建表语句
            String createTableSql = "CREATE TABLE IF NOT EXISTS users (id INT AUTO_INCREMENT PRIMARY KEY,           name VARCHAR(50) NOT NULL UNIQUE,"                   "age int(100) NOT NULL)";
      
            // 执行建表语句
            statement.executeUpdate(createTableSql);
      
            System.out.println("Table 'users' created successfully.");
        } catch (Exception e) {
             
             
            System.err.println("Error creating table: " + e.getMessage());
            e.printStackTrace();
        }
      
    • 新增记录

      //新增
      String insertSql = "INSERT INTO users (name, age) VALUES (?, ?)";
      try (PreparedStatement pstmt = connection.prepareStatement(insertSql)) {
             
             
      pstmt.setString(1, "xiaoming");
      pstmt.setInt(2, 30);
      int rowsInserted = pstmt.executeUpdate();
      System.out.println(rowsInserted + " row(s) inserted.");
      }
      
      • 查询
        ```java
        //查询
        try (Statement stmt = connection.createStatement()) {
        String sql = "SELECT id, name FROM users WHERE age > 18";
        ResultSet rs = stmt.executeQuery(sql);

      while (rs.next()) {
      int id = rs.getInt("id");
      String name = rs.getString("name");
      System.out.println("ID: " + id + ", Name: " + name);
      }
      }
      ```

      使用ResultSet对象遍历查询结果,并在操作完成后关闭所有数据库资源(如ResultSetStatementConnection)。在上述代码中,使用了try-with-resources语句自动关闭这些资源,确保即使在发生异常时也能正确清理。

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2天前
|
安全 Java 编译器
Kotlin教程笔记(27) -Kotlin 与 Java 共存(二)
Kotlin教程笔记(27) -Kotlin 与 Java 共存(二)
|
2天前
|
Java 开发工具 Android开发
Kotlin教程笔记(26) -Kotlin 与 Java 共存(一)
Kotlin教程笔记(26) -Kotlin 与 Java 共存(一)
|
2天前
|
Java 编译器 Android开发
Kotlin教程笔记(28) -Kotlin 与 Java 混编
Kotlin教程笔记(28) -Kotlin 与 Java 混编
|
Java 数据库 容器
|
8天前
|
监控 安全 Java
在 Java 中使用线程池监控以及动态调整线程池时需要注意什么?
【10月更文挑战第22天】在进行线程池的监控和动态调整时,要综合考虑多方面的因素,谨慎操作,以确保线程池能够高效、稳定地运行,满足业务的需求。
79 38
|
5天前
|
安全 Java
java 中 i++ 到底是否线程安全?
本文通过实例探讨了 `i++` 在多线程环境下的线程安全性问题。首先,使用 100 个线程分别执行 10000 次 `i++` 操作,发现最终结果小于预期的 1000000,证明 `i++` 是线程不安全的。接着,介绍了两种解决方法:使用 `synchronized` 关键字加锁和使用 `AtomicInteger` 类。其中,`AtomicInteger` 通过 `CAS` 操作实现了高效的线程安全。最后,通过分析字节码和源码,解释了 `i++` 为何线程不安全以及 `AtomicInteger` 如何保证线程安全。
java 中 i++ 到底是否线程安全?
|
9天前
|
Java 调度
[Java]线程生命周期与线程通信
本文详细探讨了线程生命周期与线程通信。文章首先分析了线程的五个基本状态及其转换过程,结合JDK1.8版本的特点进行了深入讲解。接着,通过多个实例介绍了线程通信的几种实现方式,包括使用`volatile`关键字、`Object`类的`wait()`和`notify()`方法、`CountDownLatch`、`ReentrantLock`结合`Condition`以及`LockSupport`等工具。全文旨在帮助读者理解线程管理的核心概念和技术细节。
25 1
[Java]线程生命周期与线程通信
|
7天前
|
安全 Java
在 Java 中使用实现 Runnable 接口的方式创建线程
【10月更文挑战第22天】通过以上内容的介绍,相信你已经对在 Java 中如何使用实现 Runnable 接口的方式创建线程有了更深入的了解。在实际应用中,需要根据具体的需求和场景,合理选择线程创建方式,并注意线程安全、同步、通信等相关问题,以确保程序的正确性和稳定性。
|
2天前
|
安全 Java 调度
Java中的多线程编程入门
【10月更文挑战第29天】在Java的世界中,多线程就像是一场精心编排的交响乐。每个线程都是乐团中的一个乐手,他们各自演奏着自己的部分,却又和谐地共同完成整场演出。本文将带你走进Java多线程的世界,让你从零基础到能够编写基本的多线程程序。
8 1
|
6天前
|
缓存 Java 调度
Java中的多线程编程:从基础到实践
【10月更文挑战第24天】 本文旨在为读者提供一个关于Java多线程编程的全面指南。我们将从多线程的基本概念开始,逐步深入到Java中实现多线程的方法,包括继承Thread类、实现Runnable接口以及使用Executor框架。此外,我们还将探讨多线程编程中的常见问题和最佳实践,帮助读者在实际项目中更好地应用多线程技术。
12 3