SQLite 3.8.3增加了对CTE的支持。我尝试了一些sample CTEs on this page并且它们工作正常。但是,在阅读文档并尝试调整一些示例后,我无法创建简单的测试。
首先,我创建一个包含两个字段的简单表:id
和parent
。这将创建一个简单的树或链接的记录列表:
CREATE TABLE test(id INTEGER PRIMARY KEY ASC,parent INTEGER);
现在我用几行填充它:
INSERT INTO test (parent) VALUES (NULL);
INSERT INTO test (parent) VALUES (1);
INSERT INTO test (parent) VALUES (2);
INSERT INTO test (parent) VALUES (3);
之后我有一个看起来像这样的表:
---+-------
id | parent
---+-------
1 | NULL
2 | 1
3 | 2
4 | 3
现在我想生成沿3和1之间路径的行列表:
WITH RECURSIVE test1(id,parent) AS (
VALUES(3,2)
UNION ALL
SELECT * FROM test WHERE test.parent=test1.id)
SELECT * FROM test1;
但我收到错误:
no such column: test1.id
test
和test1
都有一个id
字段,为什么它声称它不存在?我已多次查看文档,但没有看到我的错误。我做错了什么?
答案 0 :(得分:5)
有必要在test1
:
SELECT
表格
WITH RECURSIVE test1(id,parent) AS (
VALUES(3,2)
UNION ALL
SELECT test.id,test.parent FROM test,test1 WHERE test1.parent=test.id)
SELECT * FROM test1;
请注意,WHERE
子句已被反转,问题中的原始测试从当前行返回到结尾,而不是从结束返回到开始。