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

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

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

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

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


也许可以试试?

SET PASSWORD FOR 'root'@'localhost' = PASSWORD('XXX');

or

SET PASSWORD FOR 'root'@'%' = PASSWORD('XXX');

这取决于您使用的访问。

(并且不确定是否应该更改自己的字段名…)

https://dev.mysql.com/doc/refman/5.0/en/set-password.html


运行这些:

$ cd /usr/local/mysql/bin
$ ./mysqladmin -u root password 'password'

然后运行

./mysql -u root

它应该登录。现在运行 冲洗特权;

然后退出MySQL控制台并尝试登录。如果这不起作用,运行这些:

$ mysql -u root
mysql> USE mysql;
mysql> UPDATE user SET authentication_string=PASSWORD("XXXXXXX") WHERE User='root';
mysql> FLUSH PRIVILEGES;
mysql> quit

修改xxxxxx为新密码。然后再次尝试登录。

更新。 请看这个http://dev.mysql.com/doc/refman/5.7/en/resetting-permissions.html

它应该能解决你的问题。

如果你在甲骨文试试这个

ALTER USER username IDENTIFIED BY password

如果这不是你第一次设置密码,试试这个方法:

mysql> UPDATE mysql.user SET Password=PASSWORD('your_new_password')
           WHERE User='root'; 

如果你得到以下错误,很有可能你以前从未设置过密码:

ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executing this statement. 

第一次设置密码:

mysql> SET PASSWORD = PASSWORD('your_new_password');
Query OK, 0 rows affected, 1 warning (0.01 sec)

参考:https://dev.mysql.com/doc/refman/5.6/en/alter-user.html


我在Mac上也有同样的问题

首先,用沙箱模式登录mysql

mysql -u <user> -p --connect-expired-password

然后,设置密码

SET PASSWORD FOR 'root'@'localhost' = PASSWORD('XXXX');

Query OK, 0 rows affected, 1 warning (0.01 sec)

它适用于我~

通过https://dba.stackexchange.com/questions/118852/your-paswssword-has-expired-after-restart-mysql-when-updated-mysql-5-7-8-rcde


我在mac OS X 10.10.4(Yosemite)中也遇到了同样的问题。设置密码为我工作。修改mysql密码 mysql> SET PASSWORD = PASSWORD('your_password'); 查询OK, 0行受影响,1个警告(0.01秒)

在.bash_profile中设置Mysql环境路径变量,并添加以下代码行 导出路径= $路径:/ usr /地方/ mysql / bin, 然后执行如下命令。source .bash_profile


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

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

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


这招对我很管用:

ALTER USER(用户名)

我在这里找到的: http://dev.mysql.com/doc/refman/5.7/en/alter-user.html#alter-user-current


安装mysql工作台和mysql社区服务器后出现问题。在服务器安装期间获得生成的密码。 双击工作台中现有的本地实例会触发一个对话框,我可以在其中设置新密码。


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

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

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


如果您使用MySQL 5.7.6及以上版本:

ALTER USER 'root'@'localhost' IDENTIFIED BY 'MyNewPass';

如果你使用MySQL 5.7.5及更早版本:

SET PASSWORD FOR 'root'@'localhost' = PASSWORD('MyNewPass');

MySQL文档


ALTER USER 'root'@'localhost'

用这条线…


MySQL 5.7。X你需要切换到本地密码才能改变它,比如:

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

在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 "


mysql> SET PASSWORD = PASSWORD('your_new_password'); 这对我很有用。


记住版本5.7.23及以上-用户表没有列密码,而是认证字符串,所以下面的工作,而重置用户的密码。

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

UPDATE user SET authentication_string=PASSWORD("MyPassWord") WHERE user ='root'; 错误1064(42000):你有一个错误的SQL语法;查看MySQL服务器版本对应的手册,在第一行'("MyPassWord") WHERE User='root "附近使用正确的语法

解决与

ALTER USER 'root'@'localhost' IDENTIFIED BY 'MyNewPass';

以下网站参考资料

https://dev.mysql.com/doc/refman/8.0/en/resetting-permissions.html


这是适合我的方法。

Mysql >显示数据库;

错误1820 (HY000):在执行此语句之前,您必须使用ALTER USER语句重置密码。

Mysql >卸载插件validate_password;

错误1820 (HY000):在执行此语句之前,您必须使用ALTER USER语句重置密码。

Mysql > alter user 'root'@'localhost' identified by 'root'

查询OK, 0行受影响(0.01秒)

Mysql >刷新权限;

查询OK, 0行受影响(0.03秒)


Mysql 5.7.24先登录root

第一步:从日志中获取密码

 grep root@localhost /var/log/mysqld.log
    Output
        2019-01-17T09:58:34.459520Z 1 [Note] A temporary password is generated for root@localhost: wHkJHUxeR4)w

第二步:和他一起登录mysql

mysql -uroot -p'wHkJHUxeR4)w'

第三步:你输入新的根密码

SET PASSWORD = PASSWORD('xxxxx');

你会得到错误1819 (HY000):您的密码不满足当前的策略要求

如何解决?

SET GLOBAL validate_password_policy=LOW;

SET PASSWORD = PASSWORD('xxxxx');


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

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

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

例如(以我为例):

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

show slave status\G

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

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

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


我也有同样的问题。拒绝访问。

所以我的解是,

mysql> USE mysql;
mysql> SELECT User, Host, plugin FROM mysql.user;

你可以看到插入的列名

我把插件从 Unix_socket ->到mysql_native_password

输入这个

mysql > use mysql;
mysql> update user set plugin='mysql_native_password' where user='root';
mysql> flush privileges;

完成了。 我的版本是10.1.48 MariaDB ubuntu 18


要更改用户密码:

首先,以root登录 $ sudo mysql 修改用户密码 修改用户名:USER @ localhost