在IDEA的maven项目中连接并使用MySQL8.0的方法教程

yizhihongxing

以下是在IDEA的maven项目中连接并使用MySQL8.0的方法教程的完整攻略:

步骤一:安装并配置MySQL

  1. 确认已安装MySQL 8.0或以上版本,并启动MySQL服务。
  2. 使用命令行或可视化工具如Navicat等创建一个数据库,例如“testdb”。
  3. 创建一个数据库用户,并授予该用户对“testdb”数据库的全部权限。

步骤二:添加Maven依赖

  1. 按照惯例,将MySQL的驱动程序添加到项目POM文件中。
<dependency>
  <groupId>mysql</groupId>
  <artifactId>mysql-connector-java</artifactId>
  <version>8.0.13</version>
</dependency>
  1. 在IDEA中使用maven命令更新项目,以确保依赖正确导入。

步骤三:编写代码实现连接

使用以下Java代码实现MySQL连接:

import java.sql.*;

public class JdbcTest {
    static final String JDBC_DRIVER = "com.mysql.cj.jdbc.Driver";
    static final String DB_URL = "jdbc:mysql://localhost:3306/testdb";

    static final String USER = "username";
    static final String PASS = "password";

    public static void main(String[] args) {
        Connection conn = null;
        Statement stmt = null;
        try {
            // 注册 JDBC 驱动
            Class.forName(JDBC_DRIVER);

            // 打开链接
            System.out.println("连接数据库...");
            conn = DriverManager.getConnection(DB_URL, USER, PASS);

            // 执行查询
            System.out.println("实例化Statement对象...");
            stmt = conn.createStatement();
            String sql;
            sql = "SELECT id, name FROM student";
            ResultSet rs = stmt.executeQuery(sql);

            // 打印结果集
            while (rs.next()) {
                // 通过字段检索
                int id = rs.getInt("id");
                String name = rs.getString("name");

                // 打印结果
                System.out.print("ID: " + id);
                System.out.print(", Name: " + name);
                System.out.print("\n");
            }
            // 完成后关闭
            rs.close();
            stmt.close();
            conn.close();
        } catch (SQLException se) {
            // 处理 JDBC 错误
            se.printStackTrace();
        } catch (Exception e) {
            // 处理 Class.forName 错误
            e.printStackTrace();
        } finally {
            // 关闭资源
            try {
                if (stmt != null) stmt.close();
            } catch (SQLException se2) {
            }// 什么都不做
            try {
                if (conn != null) conn.close();
            } catch (SQLException se) {
                se.printStackTrace();
            }
        }
        System.out.println("Goodbye!");
    }
}

其中,JDBC_DRIVERDB_URL需要根据MySQL版本及连接信息进行修改,USERPASS分别为数据库用户名和密码。代码的主体逻辑是连接到本地的testdb数据库,读取其中的student表并输出结果。

示例说明

  1. 示例一:插入数据到数据库

若要将数据插入到数据表中,只需按照以下步骤进行:

(1)修改代码,将SQL语句改为插入语句。例如,我们要新增一条id为10,name为“Tom”的数据,修改SQL语句如下:

String sql;
sql = "INSERT INTO student (id, name) VALUES (10, 'Tom')";
stmt.executeUpdate(sql);

(2)重新编译并运行程序。新数据将会被插入到数据库中。

  1. 示例二:使用预处理语句防范SQL注入攻击

在实际开发过程中,为了避免SQL注入攻击,我们需要使用预处理语句。修改代码如下:

import java.sql.*;
public class JdbcTest3 {
    static final String JDBC_DRIVER="com.mysql.cj.jdbc.Driver";
    static final String DB_URL="jdbc:mysql://localhost:3306/testdb";
    static final String USER="username";
    static final String PASS="password";
    public static void main(String[] args){
        Connection conn=null;
        PreparedStatement stmt=null;
        try{
            Class.forName(JDBC_DRIVER);
            conn=DriverManager.getConnection(DB_URL,USER,PASS);
            String sql="SELECT id,name FROM student WHERE id=?";
            stmt=conn.prepareStatement(sql);
            stmt.setInt(1,3);
            ResultSet rs=stmt.executeQuery();
            while(rs.next()){
                int id=rs.getInt("id");
                String name=rs.getString("name");
                System.out.print("ID: "+id+", Name: "+name);
                System.out.print("\n");
            }
            rs.close();
            stmt.close();
            conn.close();
        }catch(SQLException se){
            se.printStackTrace();
        }catch(Exception e){
            e.printStackTrace();
        }finally{
            try{
                if(stmt!=null) stmt.close();
            }catch(SQLException se2){
            }
            try{
                if(conn!=null) conn.close();
            }catch(SQLException se){
                se.printStackTrace();
            }
        }
    }
}

在预处理语句中,我们使用占位符(即?)代替了实际的参数值,然后使用PreparedStatement对象的setXXX()方法为占位符赋值,可以有效防范SQL注入攻击。在此示例中,SQL语句并不复杂,所以可能看不出预处理语句的优势,但在处理复杂的SQL语句时,它将显得尤为重要。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:在IDEA的maven项目中连接并使用MySQL8.0的方法教程 - Python技术站

(0)
上一篇 2023年6月16日
下一篇 2023年6月16日

相关文章

  • Mac M1 Java 开发环境配置详解

    下面是“Mac M1 Java 开发环境配置详解”的完整攻略: 环境准备 首先,我们需要确认自己的 Mac 是否使用 Apple Silicon 硅片,在 终端 中执行下面的命令进行确认: uname -m 如果输出结果为 arm64 或 aarch64,说明你的 Mac 采用了 Apple Silicon 硅片。 安装 JDK 因为 M1 Mac 采用的是…

    Java 2023年5月20日
    00
  • jsp hibernate的分页代码第3/3页

    下面是jsp Hibernate的分页代码第3/3页的完整攻略: 分页代码介绍 在开发web应用程序时,常常需要对大量数据进行分页处理,这时我们可以使用JSP和Hibernate的结合来完成分页功能。JSP是Java服务器页面的简称,是一种动态网页技术标准,而Hibernate是一种Java框架,用于简化Java应用程序对关系数据库的访问。 在本文中,我们将…

    Java 2023年6月15日
    00
  • Spring实战之缓存使用condition操作示例

    让我来为您详细讲解“Spring实战之缓存使用condition操作示例”的完整攻略。 1. 背景介绍 Spring Cache是Spring框架的一项优秀功能,它能够优化应用程序的性能和响应时间。通过使用Spring Cache,您可以将方法结果缓存在内存中,并在需要时直接从内存中获取缓存结果,从而避免了在每次调用方法时执行相同的计算。 2. 基本原理 S…

    Java 2023年5月19日
    00
  • 详细聊聊Spring MVC重定向与转发

    详细聊聊Spring MVC重定向与转发 在Spring MVC中,重定向和转发是两种常见的请求转发方式。本文将详细介绍Spring MVC中重定向和转发的概念、区别、使用方法以及示例。 重定向 重定向是指将请求重定向到另一个URL。在Spring MVC中,我们可以使用RedirectView或RedirectAttributes类来实现重定向。下面是实现…

    Java 2023年5月17日
    00
  • Dom4j解析XML_动力节点Java学院整理

    Dom4j解析XML_动力节点Java学院整理 什么是Dom4j? Dom4j是一个为Java设计的XML API,它可以读取、写入、解析XML文件 Dom4j具有快速、高效和易于使用等特点,因此得到广泛应用 Dom4j的安装和配置 下载Dom4j:在Dom4j官网(http://dom4j.github.io/)下载最新的Dom4j Jar包 添加Dom4…

    Java 2023年5月27日
    00
  • java显示当前美国洛杉矶时间

    要在Java中显示当前美国洛杉矶时间,可以使用Java提供的时间日期API,以下是完整的攻略: 获取当前时间 使用Java提供的Date类可以获取当前时间。代码如下: Date date = new Date(); 设置时区为美国洛杉矶 使用Java提供的TimeZone类可以设置时区。代码如下: TimeZone timeZone = TimeZone.g…

    Java 2023年5月20日
    00
  • java实现多线程文件的断点续传

    针对“java实现多线程文件的断点续传”的完整攻略,我会从以下几个方面进行详细讲解: 文件断点续传的原理介绍 Java多线程实现文件断点续传的步骤 代码实现示例 常见问题及解决方案 接下来,我会一一解释。 1. 文件断点续传的原理介绍 在进行文件断点续传之前,我们需要了解一下文件的上传、下载原理,具体过程如下:1. 通过输入或选择框选择要上传/下载的文件2.…

    Java 2023年5月19日
    00
  • 基于Java编写简易的算式测试程序

    以下是“基于Java编写简易的算式测试程序”的完整攻略: 1. 需求分析 算式测试程序的基本需求是能够接受用户输入的算式,计算并输出算式的结果。该程序应包含以下功能: 能够接受用户输入的算式,例如:5+3*2-1; 能够对输入的算式进行解析和计算; 能够输出算式的计算结果。 2. 设计思路 根据需求分析,我们需要设计一个能够处理算式的类,该类应包含以下方法:…

    Java 2023年5月23日
    00
合作推广
合作推广
分享本页
返回顶部