首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >查询触发器中的错误在哪里?

查询触发器中的错误在哪里?
EN

Stack Overflow用户
提问于 2014-08-11 00:54:00
回答 1查看 32关注 0票数 0

http://sqlfiddle.com/#!2/55130中的所有结构表

我们希望下次查询触发器:

代码语言:javascript
运行
复制
CREATE TRIGGER `INSERT NEW ROW INTO MenuPosition` AFTER INSERT ON `Menu`
 FOR EACH ROW INSERT INTO MenuPosition 
SET 
MenuId=NEW.MenuId,
Position = 
(SELECT 1 + IFNULL((SELECT MAX(Position) FROM MenuPosition), 0))

但是,当我们在表Menu中插入行时,就会得到错误You cann't specify target table 'MenuPosition' for update in FROM clause Update

请告诉我,我的错误在哪里,怎样才是正确的?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-08-11 01:01:53

您的代码很难读懂。你是从哪里想到给扳机起这个名字的?

无论如何,您的代码是:

代码语言:javascript
运行
复制
CREATE TRIGGER `INSERT NEW ROW INTO MenuPosition`
    AFTER INSERT ON `Menu`
    FOR EACH ROW
BEGIN
    INSERT INTO MenuPosition 
        SET MenuId = NEW.MenuId,
            Position = (SELECT 1 + IFNULL((SELECT MAX(Position) FROM MenuPosition), 0))
END

就我个人而言,我不使用insert . . . set语法--这是不标准的。所以,我想这是个限制。下列措施应能发挥作用:

代码语言:javascript
运行
复制
CREATE TRIGGER `INSERT NEW ROW INTO MenuPosition`
    AFTER INSERT ON `Menu`
    FOR EACH ROW
BEGIN
    INSERT INTO MenuPosition(MenuID, Position)
        SELECT NEW.MenuId, 1 + IFNULL( (SELECT MAX(Position) FROM MenuPosition), 0)
END
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25234480

复制
相关文章

相似问题

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