内容简介:MySQL 1045 Access denied 和 1449 The user specified as a definer does not exist 错误处理
MySQL 使用新建用户查询时,如果数据库中有 view,可能会出现这样的错误:
SQLSTATE[28000]: Invalid authorization specification: 1045 Access denied for user 'user'@'10.174.68.21' (using password: YES)
或者
SQLSTATE[HY000]: General error: 1449 The user specified as a definer ('db_prod'@'%') does not exist
其表现是:
- 涉及到 table 的查询都正常;
- 涉及到 view 的查询都报错。
大多数情况下,出现此问题的根源是view definer设置不当。
查看所有的 definer
可以先检查下所有 view 的 definer。
select DEFINER from information_schema.VIEWS; +---------------------------+ | DEFINER | +---------------------------+ | db_prod@% | | db_prod@% | | db_prod@10.174.68.21 | | root@127.0.0.1 | +---------------------------+ 4 rows in set (0.00 sec)
可以发现,某些 view 的 definer 为db_prod@% 。
查看view的definer
进而可以查看单个 view 的 definer。
SHOW CREATE VIEW viewname CREATE ALGORITHM=UNDEFINED DEFINER=`db_prod`@`%` SQL SECURITY DEFINER VIEW `viewname` AS select * from tablename;
创建用户时需要注意的事项
如果 view 的 definer 与当前的用户不一致,可以修改或删除用户。
删除用户 DROP USER 'db_prod'@'10.174.68.21'; 修改 definer UPDATE `mysql`.`proc` p SET definer = 'root@localhost' WHERE definer='root@foobar' AND db='dbname';
在创建用户时,可以用如下 SQL.
创建用户 CREATE USER 'db_prod'@'%' IDENTIFIED BY '123456'; 授权 GRANT ALL ON dbname.* TO 'db_prod'@'%';
关键是保持 DEFINER 和创建用户时的用户名完全一致。
参考资料
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。