解决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 相关文章推荐
如何用Navicat操作MySQL
May 12 MySQL
MySQL中使用or、in与union all在查询命令下的效率对比
May 26 MySQL
解决Navicat for MySQL 连接 MySQL 报2005错误的问题
May 29 MySQL
浅谈MySQL next-key lock 加锁范围
Jun 07 MySQL
mysql获取指定时间段中所有日期或月份的语句(不设存储过程,不加表)
Jun 18 MySQL
如何搭建 MySQL 高可用高性能集群
Jun 21 MySQL
MySQL非空约束(not null)案例讲解
Aug 23 MySQL
mysql5.6主从搭建以及不同步问题详解
Dec 04 MySQL
mysql性能优化以及配置连接参数设置
May 06 MySQL
MySQL运行报错:“Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggre”解决方法
Jun 14 MySQL
MySQL数据库之存储过程 procedure
Jun 16 MySQL
前端传参数进行Mybatis调用mysql存储过程执行返回值详解
Aug 14 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 HTML代码串 截取实现代码
2009/06/29 PHP
浅谈php serialize()与unserialize()的用法
2013/06/05 PHP
js滚动条回到顶部的代码
2011/12/06 Javascript
JQUERY 获取IFrame中对象及获取其父窗口中对象示例
2013/08/19 Javascript
使图片旋转的3种解决方案
2013/11/21 Javascript
JS点击链接后慢慢展开隐藏着图片的方法
2015/02/17 Javascript
JavaScript中数据结构与算法(四):串(BF)
2015/06/19 Javascript
用canvas 实现个图片三角化(LOW POLY)效果
2016/02/18 Javascript
基于jquery实现轮播焦点图插件
2016/03/31 Javascript
jQuery实现的导航下拉菜单效果
2016/07/04 Javascript
vue.js表格组件开发的实例详解
2016/10/12 Javascript
jQuery实现 上升、下降、删除、添加一行代码
2017/03/06 Javascript
JS通过调用微信API实现微信支付功能的方法示例
2017/06/29 Javascript
Three.js利用orbit controls插件(轨道控制)控制模型交互动作详解
2017/09/25 Javascript
vue 自定义 select内置组件
2018/04/10 Javascript
JS装饰器函数用法总结
2018/04/21 Javascript
vue-cli 脚手架基于Nightwatch的端到端测试环境的过程
2018/09/30 Javascript
react+antd 递归实现树状目录操作
2020/11/02 Javascript
微信小程序实现日历小功能
2020/11/18 Javascript
[01:11:15]VGJ.S vs Secret 2018国际邀请赛小组赛BO2 第一场 8.16
2018/08/17 DOTA
Python实现八大排序算法
2016/08/13 Python
Python Socket实现简单TCP Server/client功能示例
2017/08/05 Python
Python3 执行Linux Bash命令的方法
2019/07/12 Python
Python IDLE或shell中切换路径的操作
2020/03/09 Python
基于Python把网站域名解析成ip地址
2020/05/25 Python
日本AOKI官方商城:AOKI西装
2020/06/11 全球购物
总经理秘书的岗位职责
2013/12/27 职场文书
高中考试作弊检讨书
2014/01/14 职场文书
文秘人员工作职责
2014/01/31 职场文书
服装设计专业自荐信
2014/06/17 职场文书
党旗在我心中演讲稿
2014/09/15 职场文书
房屋租赁协议书(标准版)
2014/10/02 职场文书
手机被没收的检讨书
2014/10/04 职场文书
导游词之井冈山
2019/11/20 职场文书
Nginx已编译的nginx-添加新模块
2021/04/01 Servers
Python函数对象与闭包函数
2022/04/13 Python