ubuntu phpmyadmin root 登录提示#1698 - Access denied for user 'root'@'localhost'

warning: 这篇文章距离上次修改已过1219天,其中的内容可能已经有所变动。

上次装好mysql,phpmyadmin,登录后由于默认设置的账号密码登录是看不到本地mysql的数据库,而且是无法创建数据库的,那么这就很尴尬了,看了网上其他说法,有的说修改config.inc.php,有的说修改mysql的配置文件,但似乎都并不适合我的这个错误,后来查阅了相关资料后,才发现MySQL 5.7改变了安全模式:现在MySQL root登录需要一个sudo(而密码仍然可以是空白的)。就是说,phpMyAdmin将无法使用根凭证。

那么怎么办呢?最简单(最安全)的解决方案将创建一个新用户并授予所需的权限。

MySQL赋予用户权限的命令的格式为:
grant 权限 on 数据库对象 to 用户 identified by "密码"

第一步,链接数据库
sudo mysql -u root -p

  1. 创建一个用来赋予权限的账户(例如 root_sql)
    CREATE USER 'root_sql'@'localhost' IDENTIFIED BY 'yourpasswd';

GRANT ALL PRIVILEGES ON . TO 'root_sql'@'localhost' WITH GRANT OPTION;
FLUSH PRIVILEGES;
3.更新phpMyAdmin配置
打开文件/etc/dbconfig-common/phpmyadmin.conf

[warningbox title="修改你的配置文件内容"]# dbc_dbuser: database user

the name of the user who we will use to connect to the database.

dbc_dbuser='root_sql'

dbc_dbpass: database user password

the password to use with the above username when connecting

to a database, if one is required

dbc_dbpass='yourpasswd'[/warningbox]
当然以上情况是新建用户赋予权限,但是如果你想把本来的phpmyadmin账户赋予所有权限,那么你只要执行

GRANT ALL PRIVILEGES ON . TO 'phpmyadmin'@'localhost' IDENTIFIED BY 'yourpasswd';

FLUSH PRIVILEGES;

然后再执行2,3步操作就行了

grant ALL PRIVILEGES ON . to root@"localhost" identified by "yourpasswd"; 给root所有权限 主机为localhost

作者:bier_盖子
来源:CSDN
原文:https://blog.csdn.net/teddy_dewei_lu/article/details/79659013
版权声明:本文为博主原创文章,转载请附上博文链接!

最后修改于:2020年11月24日 19:25

添加新评论