Error: Access denied for user ‘root‘@‘localhost‘ (using password: NO)

Error: Access denied for user ‘root’@‘localhost’ (using password: NO)

  • 操作系统:Ubuntu20.04
  • mysql系统:8.0.33

之前在centos7/8使用mysql_secure_installation可以直接修改mysql密码
请添加图片描述

没想到ubuntu这次使用该命令居然报错了

请添加图片描述

Error: Access denied for user ‘root’@‘localhost’ (using password: NO)

我的mysql:

请添加图片描述

我:在这里插入图片描述

查询了大部分资料,了解了一下,(using password: NO)的yes和no是输入或没输入密码,不重要。

找了网上大部分方法,都试了一下,总结出合适自己的。

我的mysql是刚安装好的(初始化没有密码)

解决过程,一,使用mysqll的安全模式免密登录

# 编辑mysql的配置文件 
vim /etc/mysql/my.cnf

# 在配置文件最下面添加,G跳到最后一行
[mysqld]
skip-grant-tables

# 重启mysql服务
systemctl restart mysql

二,登录mysql(直接登录即可)

mysql

三,设置空密码

-- 使用mysql数据库
use mysql;

-- 设置空密码
update user set authentication_string='' where user='root';

-- 退出
quit

四,修改密码(需要退出安全模式,安全模式修改不了密码)

# 重启mysql服务
systemctl restart mysql

# 空密码登录mysql
mysql -uroot -p
-- 修改密码,by‘密码’自定义即可
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'mysql';

此至,结束了
请添加图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值