Mac下mysql 8.0.22 找回密码的方法

 更新时间:2020年11月27日 13:00:03   投稿:lijiao  
这篇文章主要介绍了Mac下mysql 8.0.22 找回密码的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

Mac 最新版 MySQL 8.0.22 找回密码大全

问题描述:

昨天心血来潮, 想在Mac上体验一下最新版的MySQL的更改密码的流程, 一下子手贱用mysql_native_password替代caching_sha2_password改了plugin之后, 再用UPDATE SET來修改authentication_string, 还不记得加password(‘new password')函数, 从而导致了

ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)

原因分析:

整件事下来专坑的地方有几点:

1、password()函数在MySQL 8.0中已被弃用
2、authentication_string字段下只能是mysql加密后的41位字符串密码, 其他的会报格式错误. 这也就意味着md5(‘new password')不能起到原来password(‘new password')的功能
3、mysql 8.0 数据库默认的认证插件是caching_sha2_password, 包括你使用mysqladmin去初始化数据库也是使用这个的,所以如果想让我们平常的mysql连接客户端也可以连接上MySQL8.0的数据库那就要修改default_authentication_plugin, 也就是mysql.user里面的plugin这column

解决方案:

第一步: 关闭MySQL服务器

左上角苹果icon - System Preferences - MySQL - Stop MySQL Server

第二步: 用系统管理员权限跳过MySQL安全认证强行登陆

1.Command + Space
2.Terminal
3.sudo -i
4.cd /usr/local/mysql/bin/
5../mysqld_safe --skip-grant-tables &
6.return (就是键盘上的return点一下)
7.这时候MySQL Server再次变成running, 可以用ps -ef | grep -v ‘grep' | grep 'mysql'去查看它的PID以及启动它的mysqld_safe的PID
8../mysql

截至目前为止, 已经顺利用安全模式登陆MySQL

9. FLUSH PRIVILEGES; (这条语句在这里是把当前user表的用户信息和privilege表的权限提取到内存里, 保证可以顺利得到权限更改user表)
10. 先把user表里的root的authentication_string设为空字符串, 再用ALTER user去重新设置密码
11. 退出MySQL, 并用kill -9杀死mysqld_safe, 杀死mysql, 重新启动
12. 用新设置的密码正常登陆

USE mysql;
UPDATE user SET authentication_string = '' WHERE User = 'root';
ALTER user 'root'@'localhost' IDENTIFIED BY '123456';

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • mysql中char与varchar的区别分析

    mysql中char与varchar的区别分析

    在mysql教程中char与varchar的区别呢,都是用来存储字符串的,只是他们的保存方式不一样罢了,char有固定的长度,而varchar属于可变长的字符类型。
    2010-05-05
  • Mysql日期查询的详细介绍

    Mysql日期查询的详细介绍

    这篇文章主要介绍了Mysql日期查询的详细介绍,根据时间段进行查询数据库中单表中的数据,如果感兴趣的来了解一下
    2020-07-07
  • mysql5.6.zip格式压缩版安装图文教程

    mysql5.6.zip格式压缩版安装图文教程

    这篇文章主要为大家详细介绍了mysql5.6.zip格式压缩版安装图文教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-12-12
  • 数据库实现行列转换(mysql示例)

    数据库实现行列转换(mysql示例)

    最近突然玩起了sql语句,想着想着便给自己出了一道题目:“行列转换”。起初瞎折腾了不少时间也上网参考了一些博文,不过大多数是采用oracle数据库当中的一些便捷函数进行处理,比如”pivot”。那么,在Mysql环境下如何处理?下面通过这篇文章我们来一起看看吧。
    2016-12-12
  • MySQL系列之十四 MySQL的高可用实现

    MySQL系列之十四 MySQL的高可用实现

    这篇文章主要介绍了MySQL系列之十四 MySQL的高可用实现,从工作原理到具体的技术实现,本文详细的讲述了该项技术,以下就是详细内容,需要的朋友可以参考下
    2021-07-07
  • mysql 获取当天发布的信息的语句

    mysql 获取当天发布的信息的语句

    mysql 获取当天发布的信息的实现语句,需要的朋友可以参考下。
    2010-03-03
  • 导致MySQL做全表扫描的几种情况

    导致MySQL做全表扫描的几种情况

    这篇文章主要介绍了导致MySQL做全表扫描的几种情况,帮助大家更好的理解和学习使用MySQL,感兴趣的朋友可以了解下
    2021-03-03
  • MySQL MGR搭建过程中常遇见的问题及解决办法

    MySQL MGR搭建过程中常遇见的问题及解决办法

    这篇文章主要介绍了MySQL MGR搭建过程中常遇见的问题及解决办法,帮助大家更好的理解和学习使用MySQL,感兴趣的朋友可以了解下
    2021-03-03
  • MySql删除表中一行的实操方法

    MySql删除表中一行的实操方法

    在本篇文章中小编给大家整理了关于MySql删除表中一行的实操方法以及实例分析,需要的朋友们参考下。
    2019-05-05
  • MYSQL必知必会读书笔记第二章之版本更改

    MYSQL必知必会读书笔记第二章之版本更改

    本文是小编日常收集整理些有关mysql必知必会笔记整理第二章,小编感觉非常实用,特此分享到脚本之家平台,供大家参考
    2016-05-05

最新评论