解决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 相关文章推荐
mysql知识点整理
Apr 05 MySQL
详解MySQL 联合查询优化机制
May 10 MySQL
my.ini优化mysql数据库性能的十个参数(推荐)
May 26 MySQL
MySQL连接查询你真的学会了吗?
Jun 02 MySQL
MySQL快速插入一亿测试数据
Jun 23 MySQL
mysql优化之query_cache_limit参数说明
Jul 01 MySQL
Mysql8.0递归查询的简单用法示例
Aug 04 MySQL
MySQL去除重叠时间求时间差和的实现
Aug 23 MySQL
面试被问select......for update会锁表还是锁行
Nov 11 MySQL
教你如何让spark sql写mysql的时候支持update操作
Feb 15 MySQL
MySQL实现配置主从复制项目实践
Mar 31 MySQL
mysql字段为NULL索引是否会失效实例详解
May 30 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 什么是PEAR?(第三篇)
2009/03/19 PHP
PHP四舍五入精确小数位及取整
2014/01/14 PHP
学习php设计模式 php实现门面模式(Facade)
2015/12/07 PHP
php版微信公众平台实现预约提交后发送email的方法
2016/09/26 PHP
Smarty模板常见的简单应用分析
2016/11/15 PHP
Js+Dhtml:WEB程序员简易开发工具包(预先体验版)
2006/11/07 Javascript
一组JS创建和操作表格的函数集合
2009/05/07 Javascript
Prototype源码浅析 String部分(二)
2012/01/16 Javascript
当鼠标移动到图片上时跟随鼠标显示放大的图片效果
2013/06/06 Javascript
JavaScript link方法入门实例(给字符串加上超链接)
2014/10/17 Javascript
jQuery层级选择器用法分析
2015/02/10 Javascript
jquery简单的弹出层浮动层代码
2015/04/27 Javascript
jQuery聚合函数实例
2015/05/21 Javascript
JavaScript中setMonth()方法的使用详解
2015/06/11 Javascript
14款经典网页图片和文字特效的jQuery插件-前端开发必备
2015/08/25 Javascript
js实现数组冒泡排序、快速排序原理
2016/03/08 Javascript
手机软键盘弹出时影响布局的解决方法
2016/12/15 Javascript
js原生Ajax的封装和原理详解
2017/03/11 Javascript
vue.js单页面应用实例的简单实现
2017/04/10 Javascript
js自定义弹框插件的封装
2020/08/24 Javascript
layui table单元格事件修改值的方法
2019/09/24 Javascript
JavaScript如何处理移动端拍摄图片旋转问题
2019/11/16 Javascript
vue 使用localstorage实现面包屑的操作
2020/11/16 Javascript
使用Mixin设计模式进行Python编程的方法讲解
2016/06/21 Python
简单实现python聊天程序
2018/04/01 Python
python实现爬取图书封面
2018/07/05 Python
对python周期性定时器的示例详解
2019/02/19 Python
Python selenium根据class定位页面元素的方法
2019/02/26 Python
python库skimage给灰度图像染色的方法示例
2020/04/27 Python
Pycharm操作Git及GitHub的步骤详解
2020/10/27 Python
德国箱包网上商店:koffer24.de
2016/07/27 全球购物
struct和class的区别
2015/11/20 面试题
什么是WEB控件?使用WEB控件有哪些优势?
2012/01/21 面试题
开展党的群众路线教育实践活动剖析材料
2014/10/13 职场文书
2016自主招生校长推荐信范文
2015/03/23 职场文书
Python中 range | np.arange | np.linspace三者的区别
2022/03/22 Python