Для относительно небольшой «глубины дерева» вы можете использовать СОЮЗ самосоединений, чтобы сопоставить суммы из записей о детях с их родителями, бабушками и дедушками. Например, с таблицей с именем [tbl], содержащей
Key Value Parent Amount GroupName
--- ---------- ------ ------ ---------
1 TopItem1 5 Group1
2 TopItem2 6 Group1
3 Category1 7 Group1
4 Category2 8 Group1
5 Ca1Item1 3 20 Group1
6 Ca1Item2 3 40 Group1
7 Ca2Sub1 4 60 Group1
8 Ca2Sub2 4 80 Group1
9 Ca2Sub1It1 7 400 Group1
10 Ca2Sub1It2 7 500 Group1
11 Ca2Sub2It1 8 600 Group1
запрос
SELECT t.Value, t.Amount, t.GroupName FROM tbl t
UNION ALL
SELECT t2.Value, t1.Amount, t1.GroupName
FROM
tbl t1
INNER JOIN
tbl t2
ON t1.Parent = t2.Key
UNION ALL
SELECT t3.Value, t1.Amount, t1.GroupName
FROM
(
tbl t1
INNER JOIN
tbl t2
ON t1.Parent = t2.Key
)
INNER JOIN
tbl t3
ON t2.Parent = t3.Key
вернется
- суммы для каждой "Ценности",
- суммы для дочерних записей каждого «значения», а
- суммы для записей внуков каждой "Ценности"
производства
Value Amount GroupName
---------- ------ ---------
TopItem1 5 Group1
TopItem2 6 Group1
Category1 7 Group1
Category2 8 Group1
Ca1Item1 20 Group1
Ca1Item2 40 Group1
Ca2Sub1 60 Group1
Ca2Sub2 80 Group1
Ca2Sub1It1 400 Group1
Ca2Sub1It2 500 Group1
Ca2Sub2It1 600 Group1
Category1 20 Group1
Category1 40 Group1
Category2 60 Group1
Category2 80 Group1
Ca2Sub1 400 Group1
Ca2Sub1 500 Group1
Ca2Sub2 600 Group1
Category2 400 Group1
Category2 500 Group1
Category2 600 Group1
так что если мы обернем это в запрос кросс-таблицы
TRANSFORM Sum([Amount]) AS whatever
SELECT [GroupName]
FROM
(
SELECT t.Value, t.Amount, t.GroupName FROM tbl t
UNION ALL
SELECT t2.Value, t1.Amount, t1.GroupName
FROM
tbl t1
INNER JOIN
tbl t2
ON t1.Parent = t2.Key
UNION ALL
SELECT t3.Value, t1.Amount, t1.GroupName
FROM
(
tbl t1
INNER JOIN
tbl t2
ON t1.Parent = t2.Key
)
INNER JOIN
tbl t3
ON t2.Parent = t3.Key
)
GROUP BY [GroupName]
PIVOT [Value]
получаем
GroupName Ca1Item1 Ca1Item2 Ca2Sub1 Ca2Sub1It1 Ca2Sub1It2 Ca2Sub2 Ca2Sub2It1 Category1 Category2 TopItem1 TopItem2
--------- -------- -------- ------- ---------- ---------- ------- ---------- --------- --------- -------- --------
Group1 20 40 960 400 500 680 600 67 1648 5 6