update mysql.user set password_修改mysql密码

方法一:

登录mysql

mysql> set password for user@localhost = password('mypassword');

eg:

mysql>set password for zbxuser@localhost = password('zbxpass');

方法二:

登录mysql, 用 update 语句修改表

mysql>use mysql;

mysql>update user set password=password('mypassword') where cluase;

mysql>flush privileges;

或者

mysql>update mysql.user set password=password('mypassword') where cluase;

mysql>flush privileges;

eg:

mysql>user mysql;

mysql>update user set password=password('zbxpass') where user='zbxuser' and host='localhost';

mysql>flush privileges;

或者

mysql>update mysql.user set password=password('zbxpass') where user='zbxuser' and host='localhost';

mysql>flush privileges;

方法三:

用 mysqladmin 命令

mysqladmin -u用户名 -p旧密码 password 新密码

eg:

# mysqladmin -uzbxuser -pzbxpass password zbxpassnew;

如果忘记 mysql 的root 用户密码

方法一.

修改 /etc/my.cnf 文件

[mysqld] 中添加一行

skip-grant-tables

重启mysqld服务 systemctl restart mysqld.service,用root用户登录mysql,此时不需要输入密码了

mysql -uroot

mysql>use mysql

mysql>update user set password=password('123456') where user='root';

mysql>flush privileges;

方法二.

先停止mysql服务

启动服务

mysqld_safe --skip-grant-tables & 跳过授权表,并在后台执行。为了安全起见 再加上--skip-networking (禁止远程登录功能)

e961d56e14d9286393ecf817b2b14dca.png

mysqld_safe --skip-grant-tables &mysql-u root mysql

mysql>update user set password=password('root123') where user='root';

mysql>flush privileges;

此方法执行 mysqld_safe --skip-grant-tables 是在后台运行,有可能在改完密码之后,重启mysqld时会报错,重启失败

这时候用 ss -tnlp 查看mysqld进程,kill 掉;还有ps aux | grep mysqld 检查一下,是不是还有mysqld_safe命令在后台运行,有的话也kill掉,然后再启动mysql,这时候新密码就会 生效了;

参考:https://www.cnblogs.com/kyosusan/p/5198934.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值