Я использую модель вложенного набора для хранения большой иерархии данных в локальной базе данных 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
не является столбцом, и я предполагаю, что это потому, что его реализация подзапроса не завершена. У кого-нибудь есть идеи о том, как обойти это ограничение?
Цель запроса - получить всех непосредственных потомков данного родительского узла.