mysql设置用户权限错误解决办法:ERROR 1410 (42000): You are not allowed to create a user with GRANT

mysql设置用户权限错误解决办法:ERROR 1410 (42000): You are not allowed to create a user with GRANT



一、错误描述

使用mysql 8.0.34给一个已经存在的用户mall设置权限时,使用GRANT ALL PRIVILEGES ON mall_db.* TO 'mall'@'localhost' IDENTIFIED BY 'PW'时出现错误ERROR 1410 (42000): You are not allowed to create a user with GRANT

二、解决办法

经过网上查阅得知mysql 8.0.13以后的版本授权指令要分开执行,但是针对的是没有创建用户的场景下,一次性创建用户和指定权限,不过本次已经提前创建了用户,只进行权限的指派,所以不是这个问题导致的。
根本原因是创建用户时没有指定用户的host,这样系统会自动分配host%,而不是localhost,所以需要先更改hostlocalhost,使用select user,host from mysql.user查看目前用户的host,然后执行以下指令将用户host进行修改:

update user set host='localhost' where user='mall';

再执行以下指令指派权限:

GRANT ALL PRIVILEGES ON mall_db.* TO 'mall'@'localhost' with grant option;

问题解决

  • 7
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值