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建立连接。