我有一张桌子categories
:
ID | NAME | PARENT ID | POSITION | LEVEL | ORDER
----------------------------------------------------------------------------
1 | root | -1 | 0x | 0 | 255
2 | cars | 1 | 0x58 | 1 | 10
5 | trucks | 1 | 0x68 | 1 | 10
13 | city cars | 2 | 0x5AC0 | 2 | 255
14 | offroad cars | 2 | 0x5B40 | 2 | 255
在哪里:
ID int ident
NAME nvarchar(255)
PARENT ID int
POSITION hierarchyid
LEVEL hierarchyid GetLevel()
ORDER tinyint
此表model
指定模型名称和所属类别。例子:
ID | NAME | CATEGORY
-----------------------------
1 | Civic | 13
2 | Pajero | 14
3 | 815 | 5
4 | Avensis | 13
在哪里:
ID int ident
NAME nvarchar(255)
CATEGORY int link to ID category table
我想要做的是能够展示:
- 所有模型 - 将从根递归显示所有模型,
- 类别内的模型
cars
(包括汽车) - 来自城市汽车的模型(或其孩子,如果有的话)
如何使用 hierarchyid 进行此类过滤以及如何将结果表与模型连接起来?这是如何从某个级别显示所有模型结果的快速方法吗?