在OS X操作系统下设置MySQL root用户密码

我刚刚在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命令行!

为什么会这样?

548120 次浏览

当您登录到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';

请不要使用MySQL 8.0+

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

因为它覆盖了authentication_string,它应该是一个散列而不是纯文本,而是使用:

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

一旦你安装了MySQL,你将需要建立“根”;密码。如果您没有设置根密码,那么就没有根密码,您也不需要密码来登录。

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

使用终端输入如下:

安装:设置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

如果您不记得设置的root密码,需要重置密码,请执行以下步骤:

  1. 停止mysqld服务器,这是不同的安装

  2. 以特权绕过的安全模式运行服务器

    sudo mysqld_safe --skip-grant-tables;

  3. 在一个新的窗口连接到数据库,设置一个新的密码和刷新权限&退出:

    mysql -u root

    对于MySQL 5.7以上的版本请使用:

    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. 停止安全模式服务器并重新启动常规服务器。新密码现在可以用了。这对我来说就像一个咒语:)


请注意

< p >运行 UPDATE mysql.user SET authentication_string=null WHERE User='root'; 如果您不想为root用户设置密码。或者如果PASSWORD()函数不适合你

当我安装OS X v10.10 (Yosemite)时,我遇到了MySQL的问题。我试了很多方法,但都没用。其实我找到了一个很简单的方法。试试这个。

  1. 首次使用超级用户(su)权限登录终端。

    sudo su

  2. < p >停止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. < p >冲洗特权

    FLUSH PRIVILEGES;

  7. 你现在完了。

如果你忘记了MySQL的根密码,不记得或者想要闯入.....你可以在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

启动MySQL

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

在终端中,写入mysql -u root -p并点击返回

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

并设置密码:

SET PASSWORD = PASSWORD('new_password');

更多细节请参考本文档在这里

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' IDENTIFIED BY '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

  1. 停止mysqld服务器。
  • __abc0 __abc1→__abc2→__abc3
  • 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命令行客户端。从这里输入:

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

    • < p > FLUSH PRIVILEGES;

    • < p > 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. < p >开始MySQL:

    __abc0→__abc1→__abc2

  3. 进入终端的MySQL安装文件夹:

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

    ./mysql -u root -p
    

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

  5. 在MySQL客户端修改密码:

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

如果你忘记了你的密码或者想把它改成你的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的新密码。

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

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

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

注意:缺少sudo

停止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。

这就是对我有效的方法:

  1. 确认没有其他MySQL进程在运行。要检查这一点,请执行 : < / p >

    • 在终端执行如下命令:

      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列下的user表。我们可以将表更新为:

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

MySQL 8有了很大的变化。我发现下面对MySQL 8.0“如何重置Root密码”文档的修改适用于Mac OS X。

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

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

现有答案中提到的方法不适用于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

我认为这是可行的:

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

(注意,如果你的用户名不是root,你可能应该用你的用户名替换root。)

macOS v10.14 (Mojave)和5.7.26从Mac OS X DMG安装程序安装。

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

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

复制安装程序提供给你的密码,打开一个终端,并执行以下操作:

mysql -uroot -p
ALTER USER 'root'@'localhost' IDENTIFIED BY 'YOURPASSWORDHERE';
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';

每次重新启动苹果笔记本电脑时,我都需要这样做。

在终端试试这个:

/usr/local/bin/mysql_secure_installation

这个解决方法在我的笔记本电脑上工作!

Mac与macOS v10.14.5 (Mojave)。

MySQL 8.0.17使用家酿安装。

  • 我执行如下命令定位MySQL的路径

    brew info mysql

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

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

  • 在另一个终端运行:

    mysql -u root

  • 在那个终端里,我用:

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

  • 和完成我运行:

    FLUSH PRIVILEGES;

voilà,密码被重置。

参考资料

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

请使用

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

你可以手动关闭Mac上的MySQL,通过点击Apple菜单并打开系统设置。选择“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> FLUSH PRIVILEGES;
    
  • 现在需要修改用户密码

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

然后,您可以转到Apple菜单并打开系统首选项。选择“MySQL”首选项面板,然后点击“停止MySQL服务器”按钮来停止Mac上的MySQL服务器。

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

之前的评论都没有解决我的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

我用以下方法解决了这个问题:

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

现在您可以使用

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

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.]
$ 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