项目开发中,经常会遇到数据库的迁移。但是如果迁移过去的数据库,没用之前创建该数据库的用户,在执行视图或者存储过程的时候会报:1449 The
user specified as a definer (‘root’@’%’) does not exist那么,我们该如何解决呢??
The user specified as a definer (‘root’@’%’) does not exist
(指定为定义者的用户(根’@’%’)不存在) 此种报错主要是针对访问视图文件引起的(没有权限)
解决方法:
-
进入dos命令窗口
-
然后进入mysql的安装路径,要确保你的mysql服务是开启的;
在DOS命令窗口输入
mysql -hlocalhost -uroot -p
密码 回车
解析:在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
-
给mysql添加权限
解析:权限问题,授权 给 root 所有sql 权限
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)