我刚刚在Mac OS x上安装了MySQL,下一步是设置root用户密码,所以我接下来这样做:
启动终端应用程序以访问Unix命令行。
在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
用你想要的任何密码更改NEWPASSWORD。应该都准备好了!
更新:从MySQL 5.7开始,密码字段被重命名为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密码,需要重置密码,请执行以下步骤:
Stop the mysqld server, this varies per install
Run the server in safe mode with privilege bypass
sudo mysqld_safe --skip-grant-tables;
In a new window connect to the database, set a new password and flush the permissions & quit:
mysql -u root
For MySQL older than MySQL 5.7 use:
UPDATE mysql.user SET Password=PASSWORD('your-password') WHERE User='root';
For MySQL 5.7+ use:
USE mysql;
UPDATE mysql.user SET authentication_string=PASSWORD("your-password") WHERE User='root';
Refresh and quit:
FLUSH PRIVILEGES;
\q
Stop the safe mode server and start your regular server back. The new password should work now. It worked like a charm for me :)
Note
运行
更新mysql。SET authentication_string=null WHERE user ='root';
如果您不想为root用户设置密码。或者PASSWORD()函数不适合您。
如果你忘记了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服务器
sudo /usr/local/mysql/support-files / mysql。服务器停止
以安全模式启动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。
MySQL 8有了很大的变化。我发现MySQL 8.0“如何重置根密码”文档的以下修改适用于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
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';
您可以手动关闭Mac上的MySQL,通过点击Apple菜单并打开系统首选项。选择“MySQL”首选项面板,然后点击“停止MySQL服务器”按钮停止Mac上的MySQL服务器。
停止MySQL后,需要执行以下步骤。
你需要在skip-grant-tables模式下启动MySQL
sudo /usr/local/mysql/support-files / mysql。服务器启动——skip-grant-tables
在您的终端中,输入此命令以刷新现有权限
/usr/local/mysql/bin/mysql
现在需要修改用户密码
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY 'newpassword'
mysql >退出
然后,您可以转到Apple菜单并打开系统首选项。选择“MySQL”首选项面板,然后点击“停止MySQL服务器”按钮来停止Mac上的MySQL服务器。
最后,您可以再次进入Apple菜单并打开系统首选项。选择“MySQL”首选项面板,然后单击“启动MySQL服务器”按钮启动Mac上的MySQL服务器。
MySQL 8
关闭MySQL服务器
进入系统首选项-> MySQL
单击停止MySQL服务器按钮
打开两个终端[命令行]窗口
在第一个终端窗口中运行以下命令:
mysqld_safe --skip-grant-tables
在第二个终端窗口中执行以下操作:
4.1. 登录MySQL
mysql -u root
4.2. 在MySQL提示符中执行如下命令:
FLUSH PRIVILEGES;
ALTER USER 'root'@'localhost' IDENTIFIED BY 'NEWPASSWORD';
4.3. 退出MySQL
exit;
回到第一个终端窗口并关闭mysqld_safe
5.1. 按CTRL + Z
5.2. 运行以下命令
mysqladmin -u root -p shutdown
5.3. 输入在4.2中设置的新密码。当提示。
启动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/: ~:文本=你% 5月20日% 20 % 20了% 20,% 2 fmysql % 2 fbin % 2 fmysql。= % 20应该% 20执行% 20 % 20对,返回% 20 % 20版本% % 20 mysql中的20个。