已解决,连环错误,导入sql文件打开视图时出现1449The user specified as a definer('root'@'%') does not exist

在往navicat的数据库导入一个sql文件时出现1449The user specified as a definer('root'@'%') does not exist的错误,百度发现很多文章都说要执行sql语句:

grant all privileges on *.* to monitor@"%" identified by ".";

运行后发现并无作用,于是查找解决办法,为什么这条语句没有生效,发现mysql8中已经不支持grant all privileges on *.* to 'root'@'%' identified by '密码' with grant option这种写法,应该使用下面这条语句:

grant all privileges on *.* to 'root'@'%' ;

执行后发现又有点小问题,You are not allowed to create a user with GRANT,于是搜索这条语句,然后发现mysql8.0无法给用户授权或提示,而8.0以前的版本可以,8.0之后必须先创建用户,再给授权,命令如下:

CREATE USER '用户名'@'%' IDENTIFIED BY '密码';

之后我们再授权:

grant all privileges on *.* to 'root'@'
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值