考虑一个 SQL 表,它使用MPTT(Modified Preorder Tree Traversal)方法存储分层数据。
CREATE TABLE node (
id SERIAL NOT NULL, -- primary key
-- Nested mptt tree model.
lft INT NOT NULL,
rgt INT NOT NULL,
-- Some legacy applications still need to access parent nodes using a foreign key
parent_id INT,
FOREIGN KEY(parent_id) REFERENCES node
);
现在我想一次更新所有的 parent_id 外键。不幸的是,我的 SQL 技能真的生疏了。谁能指出一种有效的方法来做到这一点?
这就是我尝试的方式:
UPDATE node AS main
SET main.parent_id=ss.id
FROM (
SELECT parent.id
FROM node AS parent
WHERE main.lft BETWEEN parent.lft AND parent.rgt
ORDER BY parent.lft DESC) ss;
不幸的是,这似乎不起作用:
错误:FROM 中的子查询不能引用相同查询级别的其他关系
感谢您的任何提示。
PS:如果重要的话,这是在 PostgreSQL 上。