内容简介: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 和创建用户时的用户名完全一致。
参考资料
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
HTTP/2基础教程
Stephen Ludin、Javier Garza / 罗正龙、郑维智 / 人民邮电出版社 / 2018-1 / 49.00元
让网站和应用更快速、更简洁、更稳健,从而有效提升用户体验,这无疑是众多开发者梦寐以求的。然而互联网发展日新月异,HTTP/1.1协议已经难以满足现今的需求。在众多Web性能提升方案中,HTTP/2值得尝试。 本书是HTTP/2实用指南,介绍了HTTP/2的设计初衷和新特性,以及如何才能充分利用这些特性来打造高性能网站及应用。作者用定量分析方法,对比了不同网络环境下及不同浏览器上HTTP/1.......一起来看看 《HTTP/2基础教程》 这本书的介绍吧!