Mysql创建新用户后无法登录,提示 Access denied for user 'username'@'localhost' (using password: YES)

时间:2023-03-08 15:36:51
Mysql创建新用户后无法登录,提示 Access denied for user 'username'@'localhost' (using password: YES)

MySQL创建新用户后无法登录,提示 Access denied for user 'username'@'localhost' (using password: YES) ,多半是因为存在匿名用户,要解决这个问题只要删除数据库中的匿名用户即可。

MySQL新建用户后无法登录,提示 Access denied for user 'username'@'localhost' (using password: YES) 的解决方法:
请使用root账户通过命令行或PHP程序运行以下代码

  1. MySQL 创建一个新用户,用户名为username,密码为password,将localhost改为%可允许该用户登录所有主机
    CREATE USER 'username'@'localhost' IDENTIFIED BY 'password';
  2. 为该用户授权,本例将所有权限全部授予给该用户,可以将ALL PRIVILEGES改为具体的权限选项,
    *.*代表所有数据库下的所有数据表,也可以指定为具体的数据库表
    GRANT ALL PRIVILEGES ON *.* TO 'username'@'localhost' WITH GRANT OPTION
  3. 删除数据库中的空白账户(匿名账户),依次执行以下两条指命,这一步是解决这个问题的核心步骤


DELETE FROM `mysql`.`user` WHERE `user`='';
FLUSH PRIVILEGES;