我最近安装了MySQL,似乎在安装后我必须重置密码。它不让我做别的事。

现在我已经用通常的方式重置了密码:

update user set password = password('XXX') where user = root;

(顺便说一句:我花了很长时间才发现MySQL出于某种奇怪的原因将字段“password”重命名为“authentication_string”。我对这样的变化感到很不安。

不幸的是,似乎我需要改变密码不同的方式,我不知道。也许在座有人已经遇到过这个问题了?


当前回答

在mysql 5.7.x(复制)中,这个问题可能会发生,因为从用户上的密码不匹配或根用户在主用户上不存在。

例如(以我为例):

我创建了一个实例,修改了根用户的密码,在复制从服务器之前,我删除了根用户。当我做slave实例时,这个警告出现在查询上:(因为我在删除root用户之前修改了master上的密码,并且slave正在从第一个日志中读取,这实际上是一个alter root user语句)

show slave status\G

所以这里有两种解决方案:

可以在主主机和从主机上创建密码相同的root用户 可以在主主机上运行查询;

并重新连接从服务器和主服务器。

其他回答

在version 14.14 Distrib 5.7.19, macos10.12 (x86_64)上,我以以下方式登录: mysql -uroot -p然后在安装时输入mysql生成的密码。然后. .

ALTER USER 'root'@'localhost' IDENTIFIED BY '<new_password>';

例子:

ALTER USER 'root'@'localhost' IDENTIFIED BY 'Ab1234'; 查询OK, 0行受影响(0.00秒) mysql >退出 再见 $ mysql -uroot -p

你可以输入" Ab1234 "

当你使用SET PASSWORD = PASSWORD('your_new_password');它可能会为此崩溃

错误1819 (HY000):您的密码不符合当前策略 需求)

.你可以使用SET GLOBAL validate_password_policy=LOW;去解决它。

5.7版本。“password”字段已被删除。'authentication_string'替换它

use mysql;
update user set authentication_string=password('123456') where user='root';
flush privileges;

ALTER USER 'root'@'localhost'

用这条线…

如果你用mysql -u root -p启动mysql

尝试修改用户'root'@'localhost' IDENTIFIED BY 'MyNewPass';

来源:http://dev.mysql.com/doc/refman/5.7/en/resetting-permissions.html