我刚刚在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服务器

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。

其他回答

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重启时,我都需要这样做。

在终端试试这个:

/usr/local/bin/mysql_secure_installation

我认为这是可行的:

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

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

停止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 -u root -p并点击Return。

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

并设置密码:

SET PASSWORD = PASSWORD('new_password');

更多细节请参考这里的文档。