MySQL:在其自身触发器中更新表

4

显然,MySQL有一个非常烦人的限制,即不能在为同一表定义的触发器中更新该表。
我使用的是MySQL 5.1版本,我收到了错误消息:“无法在存储函数/触发器中更新表,因为它已被调用此函数/触发器的语句所使用”。

我的情况如下:

create table folder(
    id int unsigned not null auto_increment PRIMARY KEY ,
    name varchar(100) not null ,
    parentId int unsigned not null
) ;

这是一个层级文件夹结构。文件夹有名称,可能还有父文件夹(如果没有,则parentId为零)。
当删除一个文件夹时,我需要更改其中所有子文件夹的parentId,以避免它们成为不存在文件夹的子文件夹。

这很简单(几乎是微不足道的):

CREATE DEFINER=root@localhost TRIGGER onFolderDelete after delete ON folder
FOR EACH ROW update folder set parentId=0 where parentId=old.id ;

然而,MySQL不允许这样简单的触发器,因为正如我上面所说的那样,你无法在其自身触发器内更新表格。
有没有办法通过某种方式模拟其效果来实现这样的触发器?
附言:请不要建议按顺序发送两个语句(DELETE和UPDATE)。如果没有其他办法,那显然是最后的解决方案。
编辑:我使用的是MyISAM引擎(出于性能原因),因此我不能使用外键。
1个回答

3

你不能使用 ON DELETE SET NULL (或 DEFAULT) 添加外键吗?
更新DEFAULT仍未实现;SET NULL是唯一的选项...)
因此,你将得到类似以下内容:

create table folder(
id int unsigned not null auto_increment PRIMARY KEY ,
name varchar(100) not null ,
parentId int unsigned null ,
FOREIGN KEY(parentId) REFERENCES folder(id) ON UPDATE CASCADE ON DELETE SET NULL      
) ;

我正在使用不支持外键的MyISAM引擎。由于性能原因,这是针对高流量网站所必需的。 - GetFree

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接