您的位置:

mysql数据库访问错误,访问数据库失败是怎么回事

本文目录一览:

求解mysql数据库登陆错误的原因

Mysql数据库的1045错误号代表:不能连接数据库,用户名或密码错误

说明你登陆数据库的用户名或密码填写有误

检查一下是不是用户名或密码输错了,或者可能数据库IP地址填写有错误

mysql连接数据库失败,请确定数据库用户名,密码设置正确

现象

一线的工程师反映了一个奇怪的现象,刚刚从 MySQL 官网上下载了一个 MySQL 5.7.31。安装完成后,发现使用任何密码都能登陆 MySQL,修改密码也不管用,重新启动 MySQL 也不能解决。

分析

怀疑使用了 --skip-grant-tables 使用 mysqld --print-defaults 检查,没有发现。

检查登陆用户,都是 root@localhost,说明和 proxy user 没有关系。

使用 mysql --print-defaults 检查客户端是否设置默认的用户和密码,没有发现。

检查数据库中的用户和密码的相关字段:

发现一切都正常,再检查 plugin 字段,发现只有 root 用户是 auth_socket ,其它的用户都是 mysql_native_password,问题可能就出在这儿。

对 auth_socket 验证插件不了解,感觉是这个插件不安全,使用下面的命令修改后,问题解决:

update user set plugin="mysql_native_password" where user='root';

auth_socket 验证插件的使用场景

问题解决后,又仔细研究了一下 auth_socket 这个插件,发现这种验证方式有以下特点:

首先,这种验证方式不要求输入密码,即使输入了密码也不验证。这个特点让很多人觉得很不安全,实际仔细研究一下这种方式,发现还是相当安全的,因为它有另外两个限制;

只能用 UNIX 的 socket 方式登陆,这就保证了只能本地登陆,用户在使用这种登陆方式时已经通过了操作系统的安全验证;

操作系统的用户和 MySQL 数据库的用户名必须一致,例如你要登陆MySQL 的 root 用户,必须用操作系统的 root用户登陆。

auth_socket 这个插件因为有这些特点,它很适合我们在系统投产前进行安装调试的时候使用,而且也有相当的安全性,因为系统投产前通常经常同时使用操作系统的 root 用户和 MySQL 的 root 用户。当我们在系统投产后,操作系统的 root 用户和 MySQL 的 root 用户就不能随便使用了,这时可以换成其它的验证方式,可以使用下面的命令进行切换:

ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'test';

MYSQL访问数据,出现异常,这个要怎么解决

Mysql

远程连接Mysql服务器的数据库,错误代码是1130,ERROR 1130: Host xxx.xxx.xxx.xxx is not allowed to connect to this MySQL server

猜想是无法给远程连接的用户权限问题。

这样子操作mysql库,即可解决。

在本机登入mysql后,更改 “mysql” 数据库里的 “user” 表里的 “host” 项,从”localhost”改称'%'即可

mysql -u root -p

mysql;use mysql;

mysql;select 'host' from user where user='root';

mysql;update user set host = '%' where user ='root';

mysql;flush privileges;

mysql;select 'host' from user where user='root';

第一句:以权限用户root登录

第二句:选择mysql库

第三句:查看mysql库中的user表的host值(即可进行连接访问的主机/IP名称)

第四句:修改host值(以通配符%的内容增加主机/IP地址),当然也可以直接增加IP地址

第五句:刷新MySQL的系统权限相关表

第六句:再重新查看user表时,有修改。。

重起mysql服务即可完成。

mysql数据库访问错误,访问数据库失败是怎么回事

2022-11-18
mysql数据库主机连接失败(mysql数据库主机连接失败怎

2022-11-11
mysql还原数据库问题,数据库还原失败

2022-11-17
mysql数据库无法访问(mysql数据库连接不上)

2022-11-14
库访问mysql数据库,mysql怎么访问数据库

2022-11-22
mysql业务数据库连接失败(mysql业务数据库连接失败怎

2022-11-11
mysql回复数据库(mysql数据库怎么返回)

2022-11-16
mysql初始化元数据库失败,oracle数据库初始化失败

2022-11-19
使用php访问mysql数据库(php访问mysql数据库加

2022-11-11
pdo访问mysql数据库(pdo mysql)

2022-11-15
mysql备份数据库失败怎么办(mysql恢复备份数据库)

2022-11-11
关于mysql数据库重装失败(mysql数据库安装失败)

2022-11-08
连接mysql数据库连接失败,mysql数据库连接错误

2022-11-21
使用jdbc访问mysql数据库,java jdbc连接my

2022-11-22
mysql数据库写入数据库失败,mysql数据库写入数据库失

2022-11-20
链接mysql数据库失败,连接mysql数据库失败

2022-11-20
mysql删除数据库1010,mysql删除数据库所有表

2022-11-19
jdbc访问数据库之mysql,jdbc 数据库

本文目录一览: 1、如何使用jdbc连接mysql数据库 2、怎样使用jdbc访问mysql数据库 3、怎么通过jdbc连接mysql数据库 4、怎样用jdbc连接mysql数据库 如何使用jdbc连

2023-12-08
mysql数据库连接测试失败(mysql数据库连接测试失败原

2022-11-12
数据库到mysql中错误,mysql数据库问题

2022-11-24