3

我在选择具有子/父关系的多个结果时遇到困难。这是带有类别树的表格。该category表表示关系,而category_name表包含名称字符串:

[category]                 [category_name]
id, id_parent              id, name
-------------              --------------
1   NULL                   1   'animal'
2   1                      2   'mammal'
3   2                      3   'lion'
4   2                      4   'sea_creature'
5   4                      5   'lion'

作为输入,我有名字,必须翻译成 id。层次结构正好是 3 级深。例如:animal, mammal, lion,-> 1, 2, 3

如您所见lion,用于不同类别的名称。但是,上层类别是唯一的,子类别的名称在一个父类别中是唯一的。

我可以进行三个单独的查询,从它开始animal然后重新使用它id来与id_parent后续查询进行比较:

查询 #1:

SELECT
    cn.id
FROM
    category_name cn
WHERE
    cn.name = 'animal'

(将此查询的结果保存在变量中parent

查询 #2:

SELECT
    cn.id
FROM
    category_name cn
INNER JOIN category c ON cn.id = c.id
WHERE
    cn.name = 'mammal' AND c.id_parent = <parent>

等等。但我确信有更好的方法来做到这一点。

谢谢。

4

1 回答 1

4

我想这就是你要找的东西:

SELECT c1.id, c2.id, c3.id
FROM category c1
JOIN category c2 ON c1.id = c2.id_parent
JOIN category c3 ON c2.id = c3.id_parent
JOIN category_name cn1 ON c1.id = cn1.id
JOIN category_name cn2 ON c2.id = cn2.id
JOIN category_name cn3 ON c3.id = cn3.id
WHERE cn1.name = 'animal' AND cn2.name = 'mammal' AND cn3.name = 'lion'

输出

| C1ID | C2ID | C3ID |
|------|------|------|
|    1 |    2 |    3 |

在这里拉小提琴。

作为旁注,我建议您向 Google 搜索“嵌套集”和“邻接列表”。

于 2013-11-09T07:55:32.083 回答