首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >“创建ALGORITHM=UNDEFINED DEFINER`”需要超级权限

“创建ALGORITHM=UNDEFINED DEFINER`”需要超级权限
EN

Stack Overflow用户
提问于 2017-12-03 11:26:38
回答 2查看 5.1K关注 0票数 5

我正在尝试将一个旧数据库导入到我的新数据库中。

为此,我创建了一个具有与前面相同权限的用户:

除了下列命令外,几乎所有命令似乎都能工作:

代码语言:javascript
运行
复制
CREATE ALGORITHM=UNDEFINED DEFINER=`foo`@`localhost` SQL SECURITY DEFINER VIEW `wp_affiliate_wp_campaigns` AS select `wp_affiliate_wp_visits`.`affiliate_id` AS `affiliate_id`,`wp_affiliate_wp_visits`.`campaign` AS `campaign`,count(`wp_affiliate_wp_visits`.`url`) AS `visits`,count(distinct `wp_affiliate_wp_visits`.`url`) AS `unique_visits`,sum(if((`wp_affiliate_wp_visits`.`referral_id` <> 0),1,0)) AS `referrals`,round(((sum(if((`wp_affiliate_wp_visits`.`referral_id` <> 0),1,0)) / count(`wp_affiliate_wp_visits`.`url`)) * 100),2) AS `conversion_rate` from `wp_affiliate_wp_visits` group by `wp_affiliate_wp_visits`.`affiliate_id`,`wp_affiliate_wp_visits`.`campaign`;

这给了我以下错误:

代码语言:javascript
运行
复制
Error Code: 1227. Access denied; you need (at least one of) the SUPER privilege(s) for this operation

这很奇怪,因为这个表是使用与我的旧数据库具有相同权限的用户创建的(即表foo的所有权限)。

所以我的问题是:

  • 这个命令到底是做什么的?
  • 为什么我突然需要超级权限来执行它,而我的旧数据库却从来没有这样做过?
EN

回答 2

Stack Overflow用户

发布于 2018-04-13 13:37:18

我遇到了同样的问题。对我来说最有效的是脱下:

代码语言:javascript
运行
复制
  ALGORITHM=UNDEFINED DEFINER=`foo`@`localhost` SQL SECURITY DEFINER

然后你就会有:

代码语言:javascript
运行
复制
  CREATE VIEW `wp_affiliate_wp_campaigns'...

很有魅力。祝你好运!

票数 8
EN

Stack Overflow用户

发布于 2022-12-03 20:21:53

简单地试试这个

代码语言:javascript
运行
复制
CREATE ALGORITHM=UNDEFINED DEFINER=CURRENT_USER SQL SECURITY INVOKER
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47617866

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档