The user specified as a definer ('root'@'%') does not exist :报错主要是针对访问视图文件引起的(没有权限)
解决方法:
1.win+r打开dos窗口,cmd进入
2.在DOS命令窗口输入 mysql -hlocalhost -uroot -p密码 回车(先看下mysql是否设置了环境变量,如果没设置,就需要切换到mysql的bin目录下执行命令;进入mysql的安装路径之前,要确保你的mysql服务是开启的)
mysql -hlocalhost -uroot -p123456
解析:::
在DOS命令窗口输入 mysql -hlocalhost -uroot -p回车 进入mysql数据库,
其中-h表示服务器名,localhost表示本地;
-u为数据库用户名,root是mysql默认用户名;
-p为密码,如果设置了密码,可直接在-p后链接输入,如:-p123456,用户没有设置密码,显示Enter password时,直接回车即可。
注意,如果你的mysql没有安装在C盘下,你需要先使用DOS命令进入mysql的安装目录下的bin目录中。
方法如下:输入D:进入D盘,在输入cd D:\Program Files (x86)\MySQL\MySQL Server 5.7\bin 进入到mysql的bin目录下才可以输入 mysql -hlocalhost -uroot -p
3.给mysql添加权限
mysql> grant all privileges on *.* to root@"%" identified by ".";
Query OK, 0 rows affected (0.00 sec)
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)
解析::::
权限问题,授权 给 root 所有sql 权限。
操作完成后,再使用root用户查询视图发现问题已解决。
来源地址:https://blog.csdn.net/weixin_54514751/article/details/128732465