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


235

我刚刚在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不用任何密码进入命令行!

为什么是这样?

Answers:


320

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

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

使用所需的密码更改出NEWPASSWORD。应该全部设置好!

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

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

更新:在8.0.15(可能早于该版本之前)上,PASSWORD()函数不起作用,如以下注释中所述。您必须使用:

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


24
在MySQL 5.7及更高版本中,列名已更改。您将需要使用UPDATE mysql.user SET authentication_string=PASSWORD('password') WHERE User='root';代替。
卡洛斯·P

感谢您的注意。我将编辑答案以进行相应的反映。
斯科特(Scott)

8
看起来PASSWORD()函数已被弃用,您应该将放到'password'等号的右侧
kvn

6
如果您仍然无法登录,这有什么帮助?
杰克N

11
完成以下步骤后。当我试图用我的新密码重新登录我得到ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)
解冻

197

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

  1. 停止mysqld服务器,这因安装而异
  2. 使用特权绕过以安全模式运行服务器

sudo mysqld_safe --skip-grant-tables;

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

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

  1. 停止安全模式服务器,然后重新启动常规服务器。新密码现在应该可以使用了。对我来说就像是一种魅力:)

4
太好了,谢谢!在Mac OSx Mavericks(2014)上,使用sudo / Library / StartupItems / MySQLCOM / MySQLCOM stop | start | restart
Chris Adams

2
password需要authentication_string现在。
zx1986 '16

在MySQL 5.7之后,它应该是UPDATE user SET authentication_string=PASSWORD("NEWPASSWORD") WHERE User='root';,就像@Scott所说的那样。
zx1986 '16

谢谢会补充
radtek

1
MacOSX上当MySQL安装了“首选项‘面板’选项(苹果菜单- >系统偏好设置...),我发现我使用偏好设置面板上的完成步骤1首先要停止MySQL的使用。sudo kill没有就像Mac OSx一样,它会立即自动重新启动新的msql。一旦使用首选项窗格停止了mysql,我就可以手动运行mysqld_safe --skip-grant-tables
toddcscar

85

安装MySQL后,您需要建立“ root”密码。如果您没有建立root密码,那么就没有root密码,也不需要密码即可登录。

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

使用终端输入以下内容:

安装:设置root用户密码:

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

如果您输入有误,或者需要更改root密码,请使用以下命令:

更改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

5
对于拥有MySQL 5.7的用户,您应该使用update user set authentication_string=PASSWORD("NEW_PASSWORD_HERE") where User='root';而不是使用set password=...
pdm

66

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. 输入新密码,即MyNewPass

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


2
在mac os 10.12.6中,它在第二条命令ERROR
diEcho

感谢您指出在哪里可以找到文档。在Mac上,当您也可以使用sudo launchctl卸载-F /Library/LaunchDaemons/com.oracle.oss.mysql.mysqld.plist和sudo launchctl卸载-F /Library/LaunchDaemons/com.oracle.oss时,这有点令人困惑。 .mysql.mysqld.plist停止并启动mysql。使用sudo /usr/local/mysql/support-files/mysql.server stop似乎是一个更好的方法。
丹尼尔(Daniel)

59
  1. 停止mysqld服务器。

    • Mac OSX上: System Preferences > MySQL>Stop MySQL Server
    • Linux(从终端): sudo systemctl stop mysqld.service
  2. 通过特权绕过以安全模式启动服务器

    • 从终端: sudo /usr/local/mysql/bin/mysqld_safe --skip-grant-tables
  3. 新的终端窗口中:

    • sudo /usr/local/mysql/bin/mysql -u root
  4. 这将打开mysql命令行。在这里输入:

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

    • FLUSH PRIVILEGES;

    • quit

  5. 再次停止mysqld服务器,然后以正常模式重新启动它。

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

1
对于在High Sierra上运行5.7.23的情况,此方法非常有效。谢谢。
丹尼尔(Daniel)

在MySQL 8.0.11中,删除了第4步中的set函数。您在这里检查,这是可行的。stackoverflow.com/a/52579886/621951
居纳伊居尔泰金

22

由于某些原因,对于新的Mysql 5.7,Mysql的bin命令未附加到外壳程序:

  1. 安装后重新启动Mac。

  2. 启动Mysql:

    系统偏好设置> Mysql>开始按钮

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

    $ cd /usr/local/mysql/bin/

  4. 访问Mysql:

    $ ./mysql -u root -p

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

  1. 在Mysql终端中更改密码:

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


16

在终端中,编写mysql -u root -p并单击Return。输入您必须记下的当前mysql密码。并设置密码 SET PASSWORD = PASSWORD('new_password');

有关更多详细信息,请参见此处


10

如果您忘记了MySQL的root密码,不记得了或想闯入……..您可以从Linux或OS X的命令行中重置mysql数据库密码,只要您知道该框的root用户密码即可。你是在:

(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命令中,只需用您自己的新密码替换“ password”,请确保保留引号。

(4)保存并相当

FLUSH PRIVILEGES;

\q

(5)启动MySQL

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

5

当我安装OS X Yosemite时,Mysql出现了问题。我尝试了很多方法,但没有一个奏效。我实际上找到了一个很简单的方法。试试看

  1. 首先以su特权登录终端。

sudo su

  1. 停止mysql

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

  1. 以安全模式启动:

sudo mysqld_safe --skip-grant-tables

  1. 打开另一个终端,以su特权登录,不带密码登录mysql

mysql -u root

  1. 修改密码

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

  1. 同花顺特权

FLUSH PRIVILEGES;

  1. 现在完成了

非常感谢你。我为此挣扎了一下。这是最新版本的mysql的新东西吗?
jpbourbon



3

我认为这应该工作:

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

(请注意,如果不是root用户,则应该用用户名替换root)


2

停止MySQL服务器

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

以安全模式启动MySQL

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

修改root密码

/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。


2

这正是对我有效的方法:

  1. 确保没有其他MySQL进程正在运行。要执行此操作,请执行以下操作:

     a.From the terminal, run this command:
           lsof -i:3306 
       If any PID is returned, kill it using kill -9 PID
     b. Go To System Preferences > MySQL > check if any MySQL instances 
        are running, stop them.
  2. 使用以下命令启动MySQL:

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

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

2

从Mac OSX DMG安装程序安装了5.7.26的macOS 10.14+。

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

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

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

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


2

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

请使用

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

1

如果您忘记密码或想将其更改为mysql:

  1. 启动您的终端并输入:
sudo su
  1. 为您输入通行证
  2. 停止你的mysql:
sudo /usr/local/mysql/support-files/mysql.server stop
  1. 将此窗口保持打开状态,运行第二个终端窗口并在此处输入:
mysql -u root
  1. 并更改您的mysql密码:
UPDATE mysql.user SET authentication_string=PASSWORD('new_password') WHERE User='root';

其中“ new_password”-您的新密码。您不需要mysql的旧版本。

  1. 冲洗,退出并检查新通行证:
FLUSH PRIVILEGES;
  1. 关闭所有窗口,并检查mysql的新密码。祝好运。

1

MySQL 8发生了很大变化。我发现对MySQL 8.0“如何重设根密码”文档进行了以下修改适用于Mac OSX。

$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


1

让我们添加适用于我的笔记本电脑的解决方法!

Mac与Osx Mojave 10.14.5

Mysql 8.0.17与自制软件一起安装

  • 我运行以下命令以找到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;

瞧,密码已重置。

参考文献:


1

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

停止mysql之后,您需要执行以下步骤。

  • 您需要以skip-grant-tables模式启动mysql

$ sudo /usr/local/mysql/support-files/mysql.server start --skip-grant-tables

  • 在终端本身中,输入此命令以刷新现有的特权

/ usr / local / mysql / bin / mysql mysql>冲洗特权;

  • 现在您需要更改用户密码

mysql> ALTER USER'root'@'localhost'由'newpassword'标识;

mysql>退出

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

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

希望能有所帮助


1

以前的注释都无法解决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

0
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重新启动时,我都需要执行此操作。将其发布以供个人参考,希望它也对其他人有所帮助。

By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.