SQL:在嵌套集中获取节点的直接下属

问题描述 投票:0回答:1

我使用this article作为使用嵌套集模型创建数据库树结构的指南。但是,我无法让它工作:当我执行以下查询时:

SELECT node.name, (COUNT(parent.name) - 1) AS depth
FROM nested_category AS node,
        nested_category AS parent
WHERE node.lft BETWEEN parent.lft AND parent.rgt
GROUP BY node.name
ORDER BY node.lft;

我收到此错误:

#1055 - Expression #1 of ORDER BY clause is not in GROUP BY clause and
contains nonaggregated column 'test.node.lft' which is not
functionally dependent on columns in GROUP BY clause; this is 
incompatible with sql_mode=only_full_group_by

该文的评论中的某人建议按ID而不是名称进行分组,因此我用GROUP BY node.name替换了GROUP BY node.category_id并且有效。

但是,文章中的一些其他查询仍然无法正常工作。我想选择一个节点的直接子节点,例如:

SELECT node.name, (COUNT(parent.name) - (sub_tree.depth + 1)) AS depth
FROM nested_category AS node,
        nested_category AS parent,
        nested_category AS sub_parent,
        (
                SELECT node.name, (COUNT(parent.name) - 1) AS depth
                FROM nested_category AS node,
                        nested_category AS parent
                WHERE node.lft BETWEEN parent.lft AND parent.rgt
                        AND node.name = 'PORTABLE ELECTRONICS'
                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;

但我不能让它工作,因为我不知道它是如何工作的(也不知道从哪里开始)。有人可以一步一步地解释如何理解这些查询吗?

我正在使用MySQL Ver 14.14 Distrib 5.7.17。

非常感谢! 彼得

mysql sql hierarchical-data nested-sets
1个回答
0
投票

嗨,我使用相同的查询,它对我来说很好。

SELECT node.name, (COUNT(parent.name) - (sub_tree.depth + 1)) AS depth
FROM nested_category AS node,
    nested_category AS parent,
    nested_category AS sub_parent,
    (
            SELECT node.name, (COUNT(parent.name) - 1) AS depth
            FROM nested_category AS node,
                    nested_category AS parent
            WHERE node.lft BETWEEN parent.lft AND parent.rgt
                    AND node.id= 36
            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;

而不是node.name使用node.id并将HAVING depth <= 1更改为= 1,因为我不想显示头节点。

© www.soinside.com 2019 - 2024. All rights reserved.