在 OS X 上设置 MySQL 根用户密码



我刚刚在Mac OS X上安装了MySQL。下一步是设置 root 用户密码,所以我接下来做了这个:

  1. 启动终端应用程序以访问 Unix 命令行。

  2. 在Unix提示下,我执行了以下命令:

    cd /usr/local/mysql/bin
    ./mysqladmin -u root password 'password'
    

但是,当我执行命令时

./mysql -u root,这就是答案:

Welcome to the MySQL monitor.  Commands end with ; or g.
Your MySQL connection id is 224
Server version: 5.5.13 MySQL Community Server (GPL)
Copyright (c) 2000, 2010, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or 'h' for help. Type 'c' to clear the current input statement.
mysql>

我可以在没有任何密码的情况下进入mysql命令行!

这是为什么呢?

登录 MySQL 终端时尝试命令FLUSH PRIVILEGES。 如果这不起作用,请在MySQL终端中尝试以下命令集

mysql -u root
mysql> USE mysql;
mysql> UPDATE user SET password=PASSWORD("NEWPASSWORD") WHERE User='root';
mysql> FLUSH PRIVILEGES;
mysql> quit

用您想要的任何密码更改新密码。 应该都准备好了!

更新:从MySQL 5.7开始,password字段已重命名为authentication_string。 更改密码时,请使用以下查询更改密码。 所有其他命令保持不变:

mysql> UPDATE user SET authentication_string=PASSWORD("NEWPASSWORD") WHERE User='root';

对于 MySQL 8.0+ 不要使用

mysql> UPDATE mysql.user SET authentication_string='password' WHERE User='root'; 

因为它覆盖了authentication_string,它应该是哈希而不是纯文本,而是使用:

mysql> `ALTER USER 'root'@'localhost' IDENTIFIED BY 'MyNewPass';` 

如果您不记得为 root 设置的密码并需要重置密码,请按照以下步骤操作:

  1. 停止 mysqld 服务器,这因安装而异

  2. 使用权限绕过在安全模式下运行服务器

    sudo mysqld_safe --skip-grant-tables;

  3. 在新窗口中连接到数据库,设置新密码并刷新权限并退出:

    mysql -u root

    对于早于 MySQL 5.7 的 MySQL,请使用:

    UPDATE mysql.user SET Password=PASSWORD('your-password') WHERE User='root';

    对于 MySQL 5.7+,请使用:

    USE mysql;

    UPDATE mysql.user SET authentication_string=PASSWORD("your-password") WHERE User='root';

    刷新并退出:

    FLUSH PRIVILEGES;

    q

  4. 停止安全模式服务器并重新启动常规服务器。新密码现在应该可以工作了。它对我来说就像一个魅力:)

<小时 />

注意

UPDATE mysql.user SET authentication_string=null WHERE User='root';如果您不想为 root 用户设置密码。或者PASSWORD()功能对您不起作用。

安装MySQL后,您需要建立"root"密码。如果您没有建立root密码,那么,那么,没有root密码,并且您不需要密码即可登录。

因此,话虽如此,您需要建立一个root密码。

使用终端输入以下内容:

安装:设置根用户密码:

/usr/local/mysql/bin/mysqladmin -u root password NEW_PASSWORD_HERE

如果您犯了错误,或者需要更改 root 密码,请使用以下命令:

更改根密码:

cd /usr/local/mysql/bin/
./mysql -u root -p
> Enter password: [type old password invisibly]
use mysql;
update user set password=PASSWORD("NEW_PASSWORD_HERE") where User='root';
flush privileges;
quit

mysql 网站提供的说明非常清晰,比上面提到的要清楚

  1. $ sudo /usr/local/mysql/support-files/mysql.server stop
  2. $ sudo /usr/local/mysql/support-files/mysql.server start --skip-grant-tables
  3. /usr/local/mysql/bin/mysql
  4. MYSQL>刷新权限;
  5. mysql> ALTER USER 'root'@'localhost' 由 'MyNewPass' 标识;
  6. mysql> exit 或 Ctrl + z
  7. $ sudo /usr/local/mysql/support-files/mysql.server stop
  8. $ sudo /usr/local/mysql/support-files/mysql.server start
  9. /usr/local/mysql/support-files/mysql -u root -p
  10. 输入新密码,即我的新通行证

参考: http://dev.mysql.com/doc/refman/5.7/en/resetting-permissions.html

  1. 停止 mysqld 服务器。
  • Mac OS X:MySQL →系统偏好设置→停止 MySQL 服务器
  • Linux(从终端(:sudo systemctl stop mysqld.service
  1. 使用权限绕过以安全模式启动服务器

    • 从航站楼出发:sudo /usr/local/mysql/bin/mysqld_safe --skip-grant-tables
  2. 在新终端窗口中:

    • sudo /usr/local/mysql/bin/mysql -u root
  3. 这将打开 MySQL 命令行客户端。从这里输入:

    • UPDATE mysql.user SET authentication_string=PASSWORD('NewPassword') WHERE User='root';

    • FLUSH PRIVILEGES;

    • quit

  4. 再次停止 mysqld 服务器并以正常模式重新启动它。

    • Mac OS X(从终端(:sudo /usr/local/mysql/support-files/mysql.server restart
    • Linux 终端:sudo systemctl restart mysqld

对于新的MySQL 5.7,由于某种原因,MySQL的二进制命令没有附加到shell上,你必须这样做:

  1. 安装后重新启动 Mac。

  2. 启动 MySQL:

    MySQL →→"开始"按钮系统偏好设置

  3. 转到终端中的 MySQL 安装文件夹:

    cd /usr/local/mysql/bin/
    
  4. 访问 MySQL:

    ./mysql -u root -p
    

    并输入为安装提供的初始密码。

  5. 在 MySQL 客户端中,更改密码:

    mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY 'MyNewPassword';

在终端中,写mysql -u root -p并点击 Return

输入您必须记下的当前MySQL密码。

并设置密码:

SET PASSWORD = PASSWORD('new_password');

有关更多详细信息,请参阅此处的此文档。

如果您忘记了MySQL根密码,不记得或想要闯入..... 只要您知道您所在框的根用户密码,您就可以从Linux或OS X中的命令行重置MySQL数据库密码:

(1( 停止 MySQL

sudo /usr/local/mysql/support-files/mysql.server stop

(2( 以安全模式启动:

sudo mysqld_safe --skip-grant-tables

(3( 这将是一个持续的命令,直到该过程完成,因此打开另一个 shell/终端窗口,无需密码即可登录:

mysql -u root
UPDATE mysql.user SET Password=PASSWORD('password') WHERE User='root';

在上面的UPDATE命令中,只需将"密码"替换为您自己的新密码,请确保保留引号

(4(保存和相当

FLUSH PRIVILEGES;
q

(5( 启动 MySQL

sudo /usr/local/mysql/support-files/mysql.server start

我通过以下方式解决了这个问题:

  1. 关闭我的MySQL服务器:mysql.server stop
  2. 在安全模式下运行MySQL:mysqld_safe --skip-grant-tables
  3. 在另一个终端中,使用 mysql -u root
  4. 登录
  5. 在同一终端中,运行 UPDATE mysql.user SET authentication_string=null WHERE User='root'; ,然后FLUSH PRIVILEGES; ,然后退出 exit;
  6. 使用mysql.server stop停止安全模式服务器,然后启动正常服务器; mysql.server start

现在您可以通过以下方式设置新密码

ALTER USER 'root'@'localhost' IDENTIFIED WITH caching_sha2_password BY 'yourpasswd';

之前的评论都没有解决我Mac上的问题。

我使用了下面的命令,它起作用了。

brew services stop mysql
pkill mysqld
rm -rf /usr/local/var/mysql/ # NOTE: this will delete your existing database!!!
brew postinstall mysql
brew services restart mysql
mysql -u root

当我安装OS X v10.10(Yosemite(时,MySQL遇到了问题。我尝试了很多方法,但没有一种奏效。 我实际上找到了一种非常简单的方法。试试这个。

  1. 首先从超级用户 (su( 权限登录到终端。

    sudo su

  2. 停止 MySQL

    sudo /usr/local/mysql/support-files/mysql.server stop

  3. 以安全模式启动:

    sudo mysqld_safe --skip-grant-tables

  4. 打开另一个终端,以su权限登录,然后,在没有密码的情况下登录到MySQL客户端(mysql (

    mysql -u root

  5. 更改密码

    UPDATE mysql.user SET Password=PASSWORD('new_password') WHERE User='root';

  6. 冲洗权限

    FLUSH PRIVILEGES;

  7. 你现在完成了。

现有答案中提到的方法不适用于MySQL 5.7.6或更高版本。根据MySQL文档,这是推荐的方法。

B.5.3.2.3 重置 root 密码:通用说明

MySQL 5.7.6 及更高版本:

mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY 'MyNewPass';

参考: https://dev.mysql.com/doc/refman/5.7/en/resetting-permissions.html

如果您不记得密码,@radtek的答案对我有用,除了在我的情况下,我使用 brew 设置了 MySQL,这意味着他的答案的步骤 1 和 2 必须更改为:

  1. /usr/local/bin/mysql.server stop

  2. /usr/local/bin/mysqld_safe --skip-grant-tables

注:缺少sudo

我认为这应该有效:

ALTER USER 'root'@'localhost' IDENTIFIED BY 'YOURNEWPASSWORD'

(请注意,如果用户名不是 root,您可能应该将 root 替换为您的用户名。

这就是对我有用的:

  1. 确保没有其他MySQL进程正在运行。要检查这一点,请以后:

    • 在终端中,运行以下命令:

      lsof -i:3306
      

      如果返回任何 PID,请使用 kill -9 PID 将其杀死

    • 转到 MySQL系统偏好设置→检查是否有任何 MySQL 实例正在运行,停止它们。

  2. 使用以下命令启动 MySQL:

    sudo /usr/local/mysql/bin/mysqld_safe --skip-grant-tables
    
  3. 每个用户的密码分别存储在 mysql.user 表中的"用户"和"authentication_string"列下。我们可以将表更新为:

    UPDATE mysql.user SET authentication_string='your_password' where User='root'
    

停止 MySQL 服务器

sudo /usr/local/mysql/support-files/mysql.server stop

在安全模式下启动MySQL

sudo /usr/local/mysql/bin/mysqld_safe --skip-grant-tables &

更改根密码

/usr/local/mysql/bin/mysql -u root

use mysql;
UPDATE user SET authentication_string=PASSWORD('NEW_PASSWORD') WHERE user='root';
FLUSH PRIVILEGES;
exit

测试

运行/usr/local/mysql/bin/mysql -u root

现在输入新密码以开始使用MySQL。

要引用MySQL 8.0.15 +,password((函数不可用。使用以下命令。

请使用

UPDATE mysql.user SET authentication_string='password' WHERE User='root';

您可以在Mac上手动关闭MySQL,方法是单击Apple菜单并打开"系统偏好设置"。选择"MySQL"首选项面板,然后单击"停止MySQL服务器"按钮以在Mac上停止MySQL服务器。

停止 MySQL 后,您需要按照以下步骤操作。

  • 您需要在跳过授权表模式下启动MySQL

    sudo /usr/local/mysql/support-files/mysql.server start --skip-grant-tables
    
  • 在终端本身中,输入此命令以刷新现有权限

    /usr/local/mysql/bin/mysql mysql> FLUSH PRIVILEGES;
    
  • 现在您需要更改用户密码

    mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY 'newpassword';
    mysql> exit
    

然后,您可以转到Apple菜单并打开"系统偏好设置"。选择"MySQL"首选项面板,然后单击"停止MySQL服务器"按钮以在Mac上停止MySQL服务器。

最后,您可以再次转到Apple菜单并打开"系统偏好设置"。选择"MySQL"首选项面板,然后单击"启动MySQL服务器"按钮以在Mac上启动MySQL服务器。

此解决方法适用于我的笔记本电脑!

Mac with macOS v10.14.5 (Mojave(。

MySQL 8.0.17 与 Homebrew 一起安装。

  • 我运行以下命令来定位 MySQL 的路径

    brew info mysql

  • 知道路径后,我运行以下命令:

    /usr/local/Cellar/mysql/8.0.17/bin/mysqld_safe --skip-grant-table

  • 在另一个终端中,我运行:

    mysql -u root

  • 在该终端中,我使用以下方法更改了root密码:

    update mysql.user set authentication_string='NewPassword' where user='root';

  • 最后我跑:

    FLUSH PRIVILEGES;

瞧,密码被重置了。

引用

在终端中尝试一下:

/usr/local/bin/mysql_secure_installation

macOS v10.14 (Mojave( 及更高版本,从 Mac OS X DMG 安装程序安装 5.7.26。

尝试使用其他用户发布的 UPDATE 命令时,会导致以下错误:

错误 1820 (HY000(: 在执行此语句之前,必须使用 ALTER USER 语句重置密码。

复制安装程序提供给您的密码,打开终端,然后执行以下操作:

mysql -uroot -p
ALTER USER 'root'@'localhost' IDENTIFIED BY 'YOURPASSWORDHERE';

对于 MySQL 8

  1. 关闭 MySQL 服务器
  • 转到系统偏好设置 -> MySQL
  • 单击"Stop MySQL Server"按钮
  1. 打开两个终端 [命令行] 窗口

  2. 在第一个终端窗口中,运行以下命令:

mysqld_safe --skip-grant-tables
  1. 在第二个终端窗口中执行以下操作:

4.1. 登录 MySQL

mysql -u root

4.2. 在 MySQL 提示符下运行以下命令:

FLUSH PRIVILEGES;
ALTER USER 'root'@'localhost' IDENTIFIED BY 'NEWPASSWORD';

4.3. 退出 MySQL

exit;
  1. 返回第一个终端窗口并关闭mysqld_safe

5.1. 按 按 CTRL + Z

5.2. 执行以下命令

mysqladmin -u root -p shutdown

5.3. 出现提示时,输入您在4.2.中设置的新密码。

  1. 启动 MySQL 服务器 [请参阅1.]
如果您

忘记了密码或想将其更改为MySQL:

  1. 启动终端并输入:

    sudo su
    
  2. 输入系统密码

  3. 停止您的 MySQL 服务器:

    sudo /usr/local/mysql/support-files/mysql.server stop
    
  4. 将此窗口保持打开状态,运行第二个终端窗口并在此处输入:

    mysql -u root
    
  5. 并更改 MySQL 的密码:

    UPDATE mysql.user SET authentication_string=PASSWORD('new_password') WHERE User='root';
    

    其中"new_password" - 您的新密码。MySQL不需要旧密码。

  6. 刷新、退出并检查您的新密码:

    FLUSH PRIVILEGES;
    
  7. 关闭所有窗口并检查MySQL的新密码。

MySQL 8 发生了很大变化。我发现MySQL 8.0"如何重置root密码"文档的以下修改适用于Mac OS X。

创建一个临时文件,$HOME/mysql.root.txt ,使用 SQL 更新 root 密码:

ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '<new-password>';

这使用mysql_native_password来避免身份验证插件"caching_sha2_password"无法加载错误,如果我省略该选项,我会得到该错误。

停止服务器,从设置根密码的--init-file选项开始,然后重新启动服务器:

mysql.server stop
mysql.server start --init-file=$HOME/mysql.root.txt
mysql.server stop
mysql.server start
$ export PATH=$PATH:/usr/local/mysql/bin
now,to make this permanent:
$ echo 'export PATH=$PATH:/usr/local/mysql/bin' >> ~/.bash_profile
next, start mysql in safe mode:
$ sudo mysqld_safe --skip-grant-tables;
If this does not work, go to System Preferences and stop MySQL server.
next, On the **other** terminal, you may use the below:
$ mysql -u root
mysql> USE mysql;
mysql> UPDATE mysql.user SET authentication_string=null WHERE 
User='root';
mysql> FLUSH PRIVILEGES;
mysql> exit;
$ mysql -u root
mysql> ALTER USER 'root'@'localhost' IDENTIFIED WITH 
caching_sha2_password BY 'yourpassword';
$ mysql -u root -p
Enter password: 
mysql> SELECT user();
next, start the mysql server in normal mode. and you're done with resetting your root password. this worked for mysql 8.0.17 ver. for me.
thanks to everyone on top, https://stackoverflow.com/questions/36099028/error-1064-42000-you-have-an-error-in-your-sql-syntax-want-to-configure-a-pa,

https://www.houseninetytwo.com/how-to-use-mysql-in-terminal-on-mac-os-high-sierra/#:~:text=You%20may%20have%20gotten%20something,%2Fmysql%2Fbin%2Fmysql.&text=It%20should%20execute%20the%20right,return%20your%20version%20of%20MySQL。

mysqld_safe --skip-grant-tables
mysql -u root
UPDATE mysql.user SET authentication_string='yourpasswd' WHERE User='root';
FLUSH PRIVILEGES;
ALTER USER 'root'@'localhost' IDENTIFIED WITH caching_sha2_password BY 'yourpasswd';

每次MacBook重新启动时,我都需要以某种方式执行此操作。

在此处阅读更多内容。

截至 2022 年 12 月,以下内容适用于 macOS Big Sur 8.0.26 上的 MySQL 11.2.3

  1. 转到 mysql> mysql>停止服务器的系统偏好设置
  2. 打开终端并运行:mysqld_safe --skip-grant-tables
  3. 打开一个新终端并运行:mysql -u 根
  4. 运行:更改用户"根"@"本地主机",由"根"标识;
    • ROOT 将是您的新密码。
  5. 运行:刷新权限;
  6. 运行:退出
  7. 转到 mysql>启动服务器的系统偏好设置>

相关内容

  • 没有找到相关文章

最新更新