当我运行以下查询时,我得到一个错误:

SELECT
  `a`.`sl_id`                     AS `sl_id`,
  `a`.`quote_id`                  AS `quote_id`,
  `a`.`sl_date`                   AS `sl_date`,
  `a`.`sl_type`                   AS `sl_type`,
  `a`.`sl_status`                 AS `sl_status`,
  `b`.`client_id`                 AS `client_id`,
  `b`.`business`                  AS `business`,
  `b`.`affaire_type`              AS `affaire_type`,
  `b`.`quotation_date`            AS `quotation_date`,
  `b`.`total_sale_price_with_tax` AS `total_sale_price_with_tax`,
  `b`.`STATUS`                    AS `status`,
  `b`.`customer_name`             AS `customer_name`
FROM `tbl_supplier_list` `a`
  LEFT JOIN `view_quotes` `b`
    ON (`b`.`quote_id` = `a`.`quote_id`)
LIMIT 0, 30

错误信息是:

#1449 - The user specified as a definer ('web2vi'@'%') does not exist

为什么会出现这个错误?我该怎么解决呢?


当前回答

这种情况发生在我用MYSQL Workbench 6.3 Community在Windows 10上导入转储文件后,提示“root@%不存在”。即使用户存在。 首先,我试图注释掉DEFINER,但是,这没有工作。 然后,我用“root@localhost”替换了“root@%”上的字符串,并重新导入转储。这招对我很管用。

其他回答

当创建该对象的用户不再存在时,通常会发生这种情况,即从一个数据库或服务器将视图/触发器/过程导出到另一个数据库或服务器。

你有两个选择:

1. 更改DEFINER

在最初导入数据库对象时,通过从转储中删除任何DEFINER语句,这可能是最容易做到的。

稍后更改定义器就有点棘手了:

如何更改视图定义器

运行此SQL生成必要的ALTER语句 SELECT CONCAT("ALTER DEFINER= ' youruser ' @ ' host ' VIEW ", table_name, " AS ", view_definition, ";") 从information_schema.views 在table_schema =“your-database-name”; 复制并运行ALTER语句

如何更改存储过程的定义器

例子:

UPDATE `mysql`.`proc` p SET definer = 'user@%' WHERE definer='root@%'

要小心,因为这将更改所有数据库的所有定义器。

2. 创建缺少的用户

如果您在使用MySQL数据库时发现以下错误: 指定为定义器的用户('someuser'@'%')不存在' 然后你就可以解 它使用以下方法: 授予所有*。* 'someuser'@'%' IDENTIFIED BY 'complex-password'; 冲洗特权;

从http://www.lynnnayko.com/2010/07/mysql-user-specified-as-definer-root.html

这就像一个魔法——你只需要把someuser改成丢失用户的名字。在本地开发服务器上,通常只使用root。

还要考虑是否真的需要授予用户所有权限,或者他们是否可以用更少的权限。

最初创建SQL视图或过程的用户已被删除。如果您重新创建该用户,它应该可以解决您的错误。

我有同样的问题与根用户和它为我工作时,我替换

root@%

by

root@localhost

所以,如果用户'web2vi'被允许从'localhost'连接,你可以尝试:

web2vi@localhost

我远程连接到数据库了。

对于未来的谷歌人:我收到了类似的消息,试图更新数据库中不包含视图的表。经过一番挖掘,我发现我在那个表上导入了触发器,而那些是由不存在的用户定义的东西。放下触发器就解决了问题。

//更新所有或特定的程序到你想要的,使用现有的用户(我的case -root)

1) 更新mysql。SET definer = 'root@%' WHERE 1=1 LIMIT 1000; (limit子句是由于不同的mysql版本在更新时没有使用limit或没有使用where condition而导致的)

2) 冲洗特权;//或重新启动服务器