Java学习之路:JDBC篇一(mysql与Java的连接)

JDBC篇一(mysql与Java的连接)

环境:IDEA/Mysql8.0.13/Navicat Premium

外部包:mysql-connector-java-8.0.13.jar(可在官网下载对应自己数据库的版本)

前提:在windows安装mysql,navicat。

尝试使用navicat连接本地mysql,出现报错:

“caching_sha2_password”不能连接

找到原因:mysql 8.0 默认使用 caching_sha2_password 身份验证机制 —— 从原来的 mysql_native_password 更改为 caching_sha2_password。

从 5.7 升级 8.0 版本的不会改变现有用户的身份验证方法,但新用户会默认使用新的 caching_sha2_password 。

验证:
在这里插入图片描述

原因正确!

处理方法:

修改用户的密码和加密方式,这样可以将原本的caching_sha2_password改为mysql_native_password,从而弥补mysql8.0版本缺陷:

alter USER 'root'@'localhost' identified BY 'password' PASSWORD EXPIRE NEVER; #修改加密规则
alter USER 'root'@'localhost' identified WITH mysql_native_password BY 'password'; #更新一下用户的密码
alter user 'root'@'localhost' identified by '你自己的密码'; #再重置下密码:
flush privileges; #刷新权限

检查:

在这里插入图片描述

修改成功!

用新的密码验证进入navicat,连接成功!

使用java语句连接数据库:

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;

public class LinkDatabseInsert{
    public static void main(String[] args) throws ClassNotFoundException, SQLException {
        //1.注册数据库的驱动
        Class.forName("com.mysql.jdbc.Driver");
        //2.获取数据库连接(里面内容依次是:"jdbc:mysql://主机名:端口号/数据库名","用户名","登录密码")
        Connection connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/test1","root","1234");
        System.out.print(connection);
        }
  }

报错:

The server time zone value ‘Öйú±ê׼ʱ¼ä’ is unrecognized or represents more than one time

解决方法:

set global time_zone='+8:00';//启动MySQL,执行此语句:修改时间

成功解决报错问题,控制台输出结果如下:

com.mysql.cj.jdbc.ConnectionImpl@6e4784bc

至此,数据库以及和Java建立连接。

结果如下:

com.mysql.cj.jdbc.ConnectionImpl@6e4784bc

至此,数据库以及和Java建立连接。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值