解决MySQL添加新用户-ERROR 1045 (28000)的问题


Posted in MySQL onMarch 03, 2022

MySQL添加新用户,见文章底部。

按照正常思维,创建用户和设置密码什么的,应该是一个动作完成的。然而事实并非如此。

我每次都是通过在网上找代码来创建MySQL的用户。如果无效,就再搜一段。
现在我心累了,必须写个自己的教程。

1,先要连接到MySQL,工具就是在终端上输入mysql。
一般来说可以设置几个参数,重要的是-u代表用户,比如root,或者guest,-p代表密码,-h代表地址,如果是localhost,可以省略。
例子 mysql --user user --host localhost --port 3306 --password
回车之后输入密码即可。
偶尔会遇到直接使用sudo mysql可以登录的情况。

2,选择mysql数据库。

use mysql;

3,创建用户,比如用户名是demo,则使用

create user demo;

4,给用户权限。

grant all on *.* to 'demo'@'localhost' identified by 'password' ;

这里是把操作数据库的所有权限给了demo,并且设置密码是password
如果希望该用户可以创建新的用户,并授权,就使用添加with grant option

grant all on *.* to 'demo'@'localhost' identified by 'password' with grant option;

5,刷新下。flush privileges;

问题:ERROR 1045 (28000): Access denied for user ‘root’@‘localhost’ (using password: NO)
很久没用这台电脑的mysql了,今天需要连接数据库,启动数据库报错:
ERROR 1045 (28000): Access denied for user ‘root’@‘localhost’ (using password: NO)

解决MySQL添加新用户-ERROR 1045 (28000)的问题

解决方法:

查阅资料后知道了,应该使用已知的用户名和密码登陆

mysql -u root -p

然而密码忘了,试了好几遍终于试出来了:

解决MySQL添加新用户-ERROR 1045 (28000)的问题

然后修改成通用的密码,不乱折腾了:

解决MySQL添加新用户-ERROR 1045 (28000)的问题

发现很多教程都过时了,我的版本是Server version: 8.0.19 MySQL ,最新的方法:

解决MySQL添加新用户-ERROR 1045 (28000)的问题

mysql> use mysql;
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY '123';
mysql> flush privileges;

退出验证下看看有没有成功:

解决MySQL添加新用户-ERROR 1045 (28000)的问题

可以看到修改密码成功了。

然后呢,我又假装密码忘了,把忘记密码的修改密码方法演示一下:
第一步:关闭Mysql服务
首先先停止mysql服务。可通过net stop mysql或者任务管理器中关闭。

以管理员权限操作:(这是第一个窗口)

解决MySQL添加新用户-ERROR 1045 (28000)的问题

解决MySQL添加新用户-ERROR 1045 (28000)的问题

第二步:跳过Mysql密码验证
进入命令提示符(管理员登陆)操作,进入mysql目录中bin文件夹下,mysql8.0与其他版本不同的地方在于无法直接使用mysqld --skip-grant-tables来跳过密码登录。在这我们使用mysqld -console --skip-grant-tables --shared-memory来跳过权限验证。

解决MySQL添加新用户-ERROR 1045 (28000)的问题

输入执行后没有反馈,新开一个管理员窗口重新执行。(这是第二个窗口)

进入目录后,确保自己已经关闭了Mysql的服务:net stop mysql

解决MySQL添加新用户-ERROR 1045 (28000)的问题

关闭Mysql服务之后,继续在D:\mysql-8.0.19-winx64\bin目录下进行操作:
输入

mysqld --console --skip-grant-tables --shared-memory

在输入这行代码之后,如下显示,我们就已经成功跳过Mysql的密码登录了:

解决MySQL添加新用户-ERROR 1045 (28000)的问题

第三步:无密码方式进入Mysql
在上述步骤之后,再打开一个管理员模式运行的cmd.exe (这是第三个窗口)

进入mysql下的bin目录后,直接登录mysql

不需要通过net start mysql打开mysql服务

在命令行中输入以下代码

d:
cd D:\mysql-8.0.19-winx64\bin(此处输入自己电脑上的安装目录)
mysql -u root -p

如图:

解决MySQL添加新用户-ERROR 1045 (28000)的问题

此时会显示让你输入密码,直接回车,就可以成功连接Mysql。

解决MySQL添加新用户-ERROR 1045 (28000)的问题

第四步:将登陆密码设置为空
输入代码,将密码设置为空(此时还不能直接修改密码,必须先设置为空,否则会报错)
输入:

use mysql; (使用mysql数据表)
update user set authentication_string='' where user='root';(将密码置为空)
quit; (然后退出Mysql)

操作如图:

解决MySQL添加新用户-ERROR 1045 (28000)的问题

第五步:更改自己的登陆密码
这里分为两个部分

1.关闭前两个cmd窗口(一定要关闭!);
2.在第三个窗口中输入代码;

net stop mysql(关闭mysql服务,虽然会显示没有开启服务,但是以防万一)
net start mysql(再打开mysql服务)

(这里不要嫌麻烦,如果上一个mysql服务没关闭,我们依旧是无密码登陆)

操作如图:

解决MySQL添加新用户-ERROR 1045 (28000)的问题

接着输入:

cd D:\mysql-8.0.19-winx64\bin (此处输入自己电脑上的安装目录)
mysql -u root -p

(此处会显示输入密码,直接回车就好了,第四步我们已经将他置为空了)

ALTER USER 'root'@'localhost' IDENTIFIED BY 'root';(更改密码)

如图:

解决MySQL添加新用户-ERROR 1045 (28000)的问题

最后一步:验证密码是否修改成功
输入:

quit(退出mysql)
mysql -u root -p

(输入新密码,再次登录)

图示:

解决MySQL添加新用户-ERROR 1045 (28000)的问题

补充:下面看下MySQL添加新用户

按照正常思维,创建用户和设置密码什么的,应该是一个动作完成的。然而事实并非如此。

我每次都是通过在网上找代码来创建MySQL的用户。如果无效,就再搜一段。

现在我心累了,必须写个自己的教程。

1,先要连接到MySQL,工具就是在终端上输入mysql。

一般来说可以设置几个参数,重要的是-u代表用户,比如root,或者guest,-p代表密码,-h代表地址,如果是localhost,可以省略。

例子 mysql --user user --host localhost --port 3306 --password

回车之后输入密码即可。

偶尔会遇到直接使用sudo mysql可以登录的情况。

2,选择mysql数据库。

use mysql;

3,创建用户,比如用户名是demo,则使用

create user demo;

4,给用户权限。

grant all on *.* to 'demo'@'localhost' identified by 'password' ;

这里是把操作数据库的所有权限给了demo,并且设置密码是password

如果希望该用户可以创建新的用户,并授权,就使用添加with grant option

grant all on *.* to 'demo'@'localhost' identified by 'password' with grant option;

5,刷新下。flush privileges;

参考地址:https://bytes.com/topic/mysql/answers/614815-creating-new-mysql-user

到此这篇关于MySQL添加新用户-ERROR 1045 (28000)解决办法的文章就介绍到这了,更多相关MySQL ERROR 1045 (28000)内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

MySQL 相关文章推荐
如何使用Maxwell实时同步mysql数据
Apr 08 MySQL
MySQL sql_mode修改不生效的原因及解决
May 07 MySQL
MySQL 逻辑备份与恢复测试的相关总结
May 14 MySQL
MySQL8.0.18配置多主一从
Jun 21 MySQL
Mysql数据库按时间点恢复实战记录
Jun 30 MySQL
MYSQL 的10大经典优化案例场景实战
Sep 14 MySQL
MySQL中一条update语句是如何执行的
Mar 16 MySQL
数据分析数据库ClickHouse在大数据领域应用实践
Apr 03 MySQL
MySQL 条件查询的常用操作
Apr 28 MySQL
MySQL 自动填充 create_time 和 update_time
May 20 MySQL
MySQL优化之慢日志查询
Jun 10 MySQL
MySQL串行化隔离级别(间隙锁实现)
Jun 16 MySQL
MySQL之MyISAM存储引擎的非聚簇索引详解
MySQL中B树索引和B+树索引的区别详解
MySQL的InnoDB存储引擎的数据页结构详解
一文搞清楚MySQL count(*)、count(1)、count(col)区别
Mar 03 #MySQL
SQL注入篇学习之盲注/宽字节注入
MySQL为数据表建立索引的原则详解
Mar 03 #MySQL
MySQL数据库完全卸载的方法
You might like
PHP 中dirname(_file_)讲解
2007/03/18 PHP
动易数据转成dedecms的php程序
2007/04/07 PHP
php 获得汉字拼音首字母的函数
2009/08/01 PHP
PHP 自定义错误处理函数的使用详解
2013/05/10 PHP
thinkphp中ajax与php响应过程详解
2014/12/08 PHP
php实现比较两个文件夹异同的方法
2015/06/18 PHP
php中namespace及use用法分析
2016/12/06 PHP
PHP十六进制颜色随机生成器功能示例
2017/07/24 PHP
Laravel框架实现即点即改功能的方法分析
2019/10/31 PHP
关于PhpStorm设置点击编辑文件自动定位源文件的实现方式
2020/12/30 PHP
jQuery formValidator表单验证插件开源了 含API帮助、源码、示例
2008/08/14 Javascript
jqPlot Option配置对象详解
2009/07/25 Javascript
JavaScript获取图片真实大小代码实例
2014/09/24 Javascript
javascript实现无法关闭的弹框
2016/11/27 Javascript
seajs实现强制刷新本地缓存的方法分析
2017/10/16 Javascript
彻底理解js面向对象之继承
2018/02/04 Javascript
JS实现生成由字母与数字组合的随机字符串功能详解
2018/05/25 Javascript
Bootstrap标签页(Tab)插件切换echarts不显示问题的解决
2018/07/13 Javascript
vue-cli3+ts+webpack实现多入口多出口功能
2019/05/30 Javascript
vue实现一个6个输入框的验证码输入组件功能的实例代码
2020/06/29 Javascript
在vue中使用cookie记住用户上次选择的实例(本次例子中为下拉框)
2020/09/11 Javascript
[01:30:55]VG vs Mineski Supermajor 败者组 BO3 第三场 6.6
2018/06/07 DOTA
python的正则表达式re模块的常用方法
2013/03/09 Python
Python SQLAlchemy基本操作和常用技巧(包含大量实例,非常好)
2014/05/06 Python
用Python输出一个杨辉三角的例子
2014/06/13 Python
python学生管理系统学习笔记
2019/03/19 Python
使用Python实现画一个中国地图
2019/11/23 Python
优衣库澳大利亚官网:UNIQLO澳大利亚
2017/01/18 全球购物
凯撒娱乐:Caesars Entertainment
2018/02/23 全球购物
大学团支书的自我评价分享
2013/12/14 职场文书
阅兵口号
2014/06/19 职场文书
教师学习党的群众路线教育实践活动心得体会
2014/10/31 职场文书
2015年教师节主持词
2015/07/03 职场文书
2016优秀护士求职自荐信
2016/01/28 职场文书
Redis集群的关闭与重启操作
2021/07/07 Redis
腾讯云服务器部署前后分离项目之前端部署
2022/06/28 Servers