MySQL 1045 Access denied 和 1449 The user specified as a definer does not exist 错误处理

栏目: 数据库 · Mysql · 发布时间: 6年前

内容简介: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 和创建用户时的用户名完全一致。

参考资料

MySql: Some queries produce: SQLSTATE28000: Invalid authorization specification: 1045 Access denied for user

mysql如何修改所有的definer


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

HTTP/2基础教程

HTTP/2基础教程

Stephen Ludin、Javier Garza / 罗正龙、郑维智 / 人民邮电出版社 / 2018-1 / 49.00元

让网站和应用更快速、更简洁、更稳健,从而有效提升用户体验,这无疑是众多开发者梦寐以求的。然而互联网发展日新月异,HTTP/1.1协议已经难以满足现今的需求。在众多Web性能提升方案中,HTTP/2值得尝试。 本书是HTTP/2实用指南,介绍了HTTP/2的设计初衷和新特性,以及如何才能充分利用这些特性来打造高性能网站及应用。作者用定量分析方法,对比了不同网络环境下及不同浏览器上HTTP/1.......一起来看看 《HTTP/2基础教程》 这本书的介绍吧!

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

SHA 加密
SHA 加密

SHA 加密工具

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具