java怎么连接数据库mysql


前言

博主个人社区:开发与算法学习社区

博主个人主页:Killing Vibe的博客

欢迎大家加入,一起交流学习~~

在连接数据库之前,本文章将讲解JDBC是什么?工作原理是什么?再逐渐深入~

一、JDBC是什么

JDBC: Java操作数据库的规范

java.sql : 无论现在通过Java操作哪个具体的数据库,数据库厂商实现的驱动包都需要满足JDBC的标准(接口)

在这里插入图片描述

二、JDBC工作原理

JDBC为多种关系数据库提供了统一的访问方式,作为特定厂商数据库访问API的一种高级抽象,它主要包含一些通用的接口类。

JDBC访问数据库层次结构:

在这里插入图片描述

  • 不管是啥数据库 MySQL、SQLLite、Oracle 等都得实现JDBC的接口,对于程序员来说,不管操作啥数据库都是相同的套路,只是更换了具体子类(驱动)

  • MySQL也一样,它提供的Java操作数据库的驱动包必须实现JDBC标准(类似于usb标准和usb驱动)

三、下载并导入mysql的驱动

下面告诉大家如何导入mysql的驱动包

3.1 下载mysql-connector-java-5.1.47.jar

资源链接mysql-connector-java-5.1.47.jar

拓展:*.jar 就是把一系列编译好的class文件打包压缩后的文件,其他程序引入这个jar包就有了这个包中的所有类(等于别人写好的东西直接拿来用)

在这里插入图片描述

3.2 idea项目导入jar包

  1. 右键项目(模块)名,找到打开模块设置

在这里插入图片描述

  1. 找到 库 ,然后点击加号,把下载好的jar包导入进去

在这里插入图片描述

  1. 当外部库显示如下图,表示导入完成

在这里插入图片描述

四、JDBC的使用(完整代码见文末)

所有Java操作关系型数据库,无论是哪种数据库,套路都是一样的,JPA,MyBatis都是JDBC的封装而已。

其实连接数据库主要就分了六个步骤

  1. 获取数据源DataSource,配置连接地址,用户名,密码等
  2. 获取连接对象,就是发送网络请求,建立和数据库的连接Connection
  3. 获取执行SQL的对象PreparedStatement对象,封装的SQL语句
  4. 执行更新操作 executeUpdate => int 本次更新受影响的行数;执行查询executeQuery => Result结果集
  5. 遍历结果集 ResultSet对象,每当调用一次next方法就从结果集中取出一行数据,resultSetXX(“列名”) => 获取本行数据的具体属性值
  6. 操作关闭之后关闭资源,resultSet,Connection对象

4.1 获取数据源

在这里插入图片描述

解释一下URL里面的内容:

1.请求协议,类似于https协议,MySQL的驱动包背后都是一些网络请求,操作数据库其实就是在发起网络请求

jdbc:mysql://

2.配置MySQL的IP和端口号,127.0.0.1 是本机IP,3306是端口号,类似于一个程序在操作系统中的一个id。test是要想连接的数据库名称(自定义)

127.0.0.1:3306/test
  1. 连接的字符集编码格式是UTF-8, 不发起ssl请求,加密请求,不安全的连接
characterEncoding=UTF-8&useSSL=false

4.2 获取连接对象

这一步才会向数据库服务器发起请求

在这里插入图片描述

4.3获取执行SQL的对象

sql 语句根据自己的数据库和表来写,这里仅作示例:

在这里插入图片描述

4.4 执行查询或者更新操作

1.执行更新操作 executeUpdate 返回 int 本次更新受影响的行数

2.执行查询executeQuery 返回 Result结果集

示例如下:

在这里插入图片描述

4.5 遍历结果集

每当调用一次next方法就从结果集中取出一行数据,resultSet.XX(“列名”) => 获取本行数据的具体属性值

在这里插入图片描述

4.6 关闭资源

数据库属于资源操作,一定要记得关闭资源,结果集对象,连接对象

在这里插入图片描述

五、完整代码

完整代码如下,仅作示例,相关属性需要根据自己实际情况修改

import com.mysql.jdbc.jdbc2.optional.MysqlDataSource;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

/**
 * @author Dianzhi Han
 * @version 1.0
 * @description: TODO
 * @date 2022/10/27 20:24
 */
public class JdbcTest {
    public static void main(String[] args) throws SQLException {
        // 1.获取数据源 - 数据具体是从哪个数据库来的
        // DataSource这个接口无论哪种具体的数据库驱动都要实现此接口,具体是什么数据库名称数据库名称 + DataSource
        // MySQLDataSource
        // SQliteDataSource
        MysqlDataSource dataSource = new MysqlDataSource();
        // 1.1 设置数据源的连接地址,用户名,密码等属性
        // 发起TCP请求,按照指定的协议(jdbc协议)连接到数据库的服务端
        // 大家根据自己的MySQL的情况,数据库的名称,密码,用户名等等需要修改
        dataSource.setURL("jdbc:mysql://127.0.0.1:3306/test?characterEncoding=UTF-8&useSSL=false");
        dataSource.setUser("root");
        dataSource.setPassword("123");
        // 2.获取数据库连接 - Connection接口的对象
        // 这一步才会向数据库服务器发起请求
        Connection connection = dataSource.getConnection();
        // 3.执行具体的SQL语句,每个SQL语句对应一个PrepareStatement对象
        String sql = "select sex from teacher where username = ?";
        PreparedStatement statement = connection.prepareStatement(sql);
        // 1就是将第一个?的内容替换为具体的值(此处就把name = ? => name = 孙悟空)
        // set数据类型要和数据库的列属性保持一致
        statement.setString(1,"孙悟空");
        // 4.具体执行操作,增删改 excuteUpdate() => int 本次修改操作受影响的行数
        // 查询操作 select =》 excuteQuery() => ResultSet =》 查询结果集
        ResultSet resultSet = statement.executeQuery();
        // 5.遍历结果集
        while (resultSet.next()) {
            String pass = resultSet.getString("sex");
            System.out.println(pass);
        }
        // 6.数据库属于资源操作,一定要记得关闭资源,结果集对象,连接对象
        resultSet.close();
        connection.close();
    }
}

拓展

  1. 获取数据源有两种方式,一个是DataSource(实际用到的),另一种是DriverManager(不推荐使用),关于两者的区别这里就不展开了

  2. 具体执行SQL的对象也有两种方式,一个是PreparedStatement对象(推荐使用),另外一个是Statement对象(不推荐使用),两者区别大家可以去网上看一下~

  • 43
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 44
    评论
要使用Java连接MySQL数据库,需要下载并安装MySQL Connector/J驱动程序。以下是安装步骤: 1. 访问MySQL官方网站,下载MySQL Connector/J驱动程序。当前最新版本为8.0.20,下载地址为:https://dev.mysql.com/downloads/connector/j/ 2. 下载后,将mysql-connector-java-8.0.20.jar文件复制到项目的classpath路径下。 3. 在Java代码中添加连接MySQL数据库的代码,示例代码如下: ``` import java.sql.Connection; import java.sql.DriverManager; import java.sql.SQLException; public class MySQLConnect { public static void main(String[] args) { Connection conn = null; try { // 加载MySQL驱动程序 Class.forName("com.mysql.cj.jdbc.Driver"); // 获取数据库连接 String url = "jdbc:mysql://localhost:3306/test"; String user = "root"; String password = "root"; conn = DriverManager.getConnection(url, user, password); System.out.println("数据库连接成功!"); } catch (SQLException e) { System.out.println("数据库连接失败:" + e.getMessage()); } catch (ClassNotFoundException e) { System.out.println("找不到MySQL驱动程序:" + e.getMessage()); } finally { try { if (conn != null) { conn.close(); } } catch (SQLException e) { System.out.println("关闭数据库连接失败:" + e.getMessage()); } } } } ``` 以上代码演示了如何连接本地MySQL数据库,如果需要连接远程MySQL数据库,只需要将url中的localhost改为远程MySQL服务器的IP地址即可。同时,需要确保远程MySQL服务器已经允许远程连接。
评论 44
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Killing Vibe

谢谢您的打赏!博主会持续更新

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值