MySQL 错误 1449:指定为定义者的用户不存在

MySQL error 1449: The user specified as a definer does not exist(MySQL 错误 1449:指定为定义者的用户不存在)
本文介绍了MySQL 错误 1449:指定为定义者的用户不存在的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

当我运行以下查询时,出现错误:

When I run the following query I get an error:

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

为什么我会收到那个错误?我该如何解决?

Why am I getting that error? How do I fix it?

推荐答案

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

This commonly occurs when exporting views/triggers/procedures from one database or server to another as the user that created that object no longer exists.

您有两个选择:

这在最初导入数据库对象时可能是最简单的,方法是从转储中删除任何 DEFINER 语句.

This is possibly easiest to do when initially importing your database objects, by removing any DEFINER statements from the dump.

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

Changing the definer later is a more little tricky:

  1. 运行此 SQL 以生成必要的 ALTER 语句

  1. Run this SQL to generate the necessary ALTER statements

SELECT CONCAT("ALTER DEFINER=`youruser`@`host` VIEW ", 
table_name, " AS ", view_definition, ";") 
FROM information_schema.views 
WHERE table_schema='your-database-name';

  • 复制并运行 ALTER 语句

  • Copy and run the ALTER statements

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

    示例:

    Howtochangethedefinerforstoredprocedures

    Example:

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

    小心,因为这会改变所有数据库的所有定义.

    Be careful, because this will change all the definers for all databases.

    如果您在使用 MySQL 数据库时发现以下错误:

    If you've found following error while using MySQL database:

    The user specified as a definer ('someuser'@'%') does not exist`
    

    然后就可以解决了它通过使用以下:

    Then you can solve it by using following :

    GRANT ALL ON *.* TO 'someuser'@'%' IDENTIFIED BY 'complex-password';
    FLUSH PRIVILEGES;
    

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

    这很有效 - 您只需将 someuser 更改为丢失用户的名称.在本地开发服务器上,您通常可能只使用 root.

    This worked like a charm - you only have to change someuser to the name of the missing user. On a local dev server, you might typically just use root.

    还要考虑您是否真的需要授予用户 ALL 权限,或者他们是否可以使用更少的权限.

    Also consider whether you actually need to grant the user ALL permissions or whether they could do with less.

    这篇关于MySQL 错误 1449:指定为定义者的用户不存在的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

  • 本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

    相关文档推荐

    Hibernate reactive No Vert.x context active in aws rds(AWS RDS中的休眠反应性非Vert.x上下文处于活动状态)
    Bulk insert with mysql2 and NodeJs throws 500(使用mysql2和NodeJS的大容量插入抛出500)
    Flask + PyMySQL giving error no attribute #39;settimeout#39;(FlASK+PyMySQL给出错误,没有属性#39;setTimeout#39;)
    auto_increment column for a group of rows?(一组行的AUTO_INCREMENT列?)
    Sort by ID DESC(按ID代码排序)
    SQL/MySQL: split a quantity value into multiple rows by date(SQL/MySQL:按日期将数量值拆分为多行)