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

时间:2011-06-24 23:37:57

标签: mysql macos passwords

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

  1. 启动终端应用程序以访问Unix命令行。
  2. 在Unix提示符下,我执行了以下命令:

    $ cd /usr/local/mysql/bin
    $ ./mysqladmin -u root password 'password'
    
  3. 但是,当我执行命令

    $ ./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命令行!

    为什么会这样?

24 个答案:

答案 0 :(得分:308)

登录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

使用您想要的任何密码更改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';

答案 1 :(得分:190)

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

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

    sudo mysqld_safe --skip-grant-tables;

    1. 在新窗口中连接到数据库,设置新密码并刷新权限&退出:
    2. 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. 停止安全模式服务器并重新启动常规服务器。新密码现在可以使用了。对我来说就像一个魅力:)

答案 2 :(得分:84)

安装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

答案 3 :(得分:56)

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的> FLUSH PRIVILEGES;
  5. MySQL的> ALTER USER' root' @' localhost'通过' MyNewPass';
  6. 识别
  7. MySQL的> exit或Ctrl + z
  8. $ sudo /usr/local/mysql/support-files/mysql.server stop
  9. $ sudo /usr/local/mysql/support-files/mysql.server start
  10. /usr/local/mysql/support-files/mysql -u root -p
  11. 输入新密码,即MyNewPass
  12. 参考:http://dev.mysql.com/doc/refman/5.7/en/resetting-permissions.html

答案 4 :(得分:53)

  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

答案 5 :(得分:23)

对于新的Mysql 5.7由于某种原因,Mysql的bin命令没有附加到shell:

  1. 安装后重启Mac。

  2. 启动Mysql:

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

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

    $ cd /usr/local/mysql/bin/

  4. 访问Mysql:

    $ ./mysql -u root -p

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

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

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

答案 6 :(得分:15)

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

有关详细信息,请参阅此文档here

答案 7 :(得分: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

答案 8 :(得分:5)

当我安装OS X Yosemite时,我遇到了Mysql的问题。我尝试了很多方法但没有工作。我实际上找到了一个非常简单的方法试试这个。

  1. 首先从su权限登录终端。
  2. sudo su

    1. 停止mysql
    2. sudo /usr/local/mysql/support-files/mysql.server stop

      1. 以安全模式开始:
      2. sudo mysqld_safe --skip-grant-tables

        1. 打开另一个终端,以su权限登录,以无密码登录mysql
        2. mysql -u root

          1. 更改密码
          2. UPDATE mysql.user SET Password=PASSWORD('new_password') WHERE User='root';

            1. 刷新权限
            2. FLUSH PRIVILEGES;

              1. 你现在完成了

答案 9 :(得分:5)

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

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

MySQL 5.7.6及更高版本:

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

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

答案 10 :(得分:3)

如果您忘记了密码,@radtek's answer对我有用,除非在我的情况下我有set up MySQL using brew,这意味着他的答案的第1步和第2步必须更改为:

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

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

  3. 注意:缺少sudo

答案 11 :(得分: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'
    

答案 12 :(得分:2)

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

答案 13 :(得分:2)

我认为这应该有效:

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

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

答案 14 :(得分: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。

答案 15 :(得分:1)

MySQL 8发生了很多变化。我发现MySQL 8.0 "How to Reset the Root Password" documentation的以下修改适用于Mac OS X。

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

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

这使用mysql_native_password来避免Authentication plugin 'caching_sha2_password' cannot be loaded错误,如果我省略该选项,则会出现此错误。

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

mysql.server stop mysql.server start --init-file=$HOME/mysql.root.txt mysql.server stop mysql.server start

答案 16 :(得分:1)

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

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

          其中&#34; new_password&#34; - 你的新通行证。你不需要为mysql做旧传递。

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

答案 17 :(得分:1)

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

  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';

答案 18 :(得分:0)

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

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

错误1820(HY000):必须先使用ALTER USER语句重置密码。

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

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

答案 19 :(得分: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重新启动时,我都需要执行此操作。将此内容发布以供个人参考,希望对其他人也有帮助。

答案 20 :(得分:0)

在终端中尝试: /usr/local/bin/mysql_secure_installation

答案 21 :(得分:0)

让我们添加可在笔记本电脑上使用的替代方法!

装有Osx Mojave 10.14.5的Mac

Mysql 8.0.17与自制软件一起安装

  • 我运行以下命令来找到mysql的路径

    brew info mysql

  • 一旦知道路径,我就运行这个:

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

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

    mysql -u root

  • 在该终端内,我使用:p更改了root密码。

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

  • 最后我要运行:

    FLUSH PRIVILEGES;

瞧,密码已重置。

References :

答案 22 :(得分:0)

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

请使用

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

答案 23 :(得分:0)

您可以在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>冲洗特权;

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

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

     

mysql>退出

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

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

希望有帮助