Подзапрос в запросе SQLite не работает - PullRequest
2 голосов
/ 09 мая 2009

Я использую модель вложенного набора для хранения большой иерархии данных в локальной базе данных SQLite на iPhone. Я прочитал техническую статью MySQL на их веб-сайте о том, как это сделать, но один из предлагаемых ими запросов (и которые мне нужны) не работает с SQLite, и я не уверен, как чтобы обойти это.

SELECT node.name, (COUNT(parent.name) - (sub_tree.depth + 1)) AS depth
FROM line_items AS node,
    line_items AS parent,
    line_items AS sub_parent,
    (SELECT node.name, (COUNT(parent.name) - 1) AS depth
        FROM line_items AS node,
        line_items AS parent
        WHERE node.lft BETWEEN parent.lft AND parent.rgt
        AND node.name = 'Power Up'
        GROUP BY node.name
        ORDER BY node.lft
    ) AS sub_tree
WHERE node.lft BETWEEN parent.lft AND parent.rgt
    AND node.lft BETWEEN sub_parent.lft AND sub_parent.rgt
    AND sub_parent.name = sub_tree.name
GROUP BY node.name
HAVING depth <= 1
ORDER BY node.lft;

SQLite сообщает, что sub_tree.name не является столбцом, и я предполагаю, что это потому, что его реализация подзапроса не завершена. У кого-нибудь есть идеи о том, как обойти это ограничение?

Цель запроса - получить всех непосредственных потомков данного родительского узла.

1 Ответ

3 голосов
/ 09 мая 2009

Попробуйте использовать «имя узла node.name AS» в подзапросе, т.е.

SELECT node.name, (COUNT(parent.name) - (sub_tree.depth + 1)) AS depth
FROM line_items AS node,
    line_items AS parent,
    line_items AS sub_parent,
    (SELECT node.name AS name, (COUNT(parent.name) - 1) AS depth
        FROM line_items AS node,
        line_items AS parent
        WHERE node.lft BETWEEN parent.lft AND parent.rgt
        AND node.name = 'Power Up'
        GROUP BY node.name
        ORDER BY node.lft
    ) AS sub_tree
WHERE node.lft BETWEEN parent.lft AND parent.rgt
    AND node.lft BETWEEN sub_parent.lft AND sub_parent.rgt
    AND sub_parent.name = sub_tree.name
GROUP BY node.name
HAVING depth <= 1
ORDER BY node.lft;

По крайней мере, кажется, чтобы избавиться от ошибки.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...