sum Preis von Kindern in anderen Tabelle mysql

Ich habe zwei Tabellen, eine Speicherdatenhierarchie für untergeordnete und übergeordnete Elemente sowie andere Pfade und Nachkommen.

+----------+------------+-----------+
| userid   |    parent  |    price  |
+----------+------------+------------
| 1        |    null    |      20   | 
| 2        |      1     |      20   | 
| 3        |      1     |      20   | 
| 4        |      2     |      20   | 
| 5        |      2     |      20   | 
| 6        |      3     |      20   | 
| 7        |      4     |      20   | 
+----------+------------+-----------+

Ich muss alle Benutzer-IDs mit übergeordnetem Element 1 abrufen, dann Nachkomme in einer anderen Tabelle abrufen und nach Benutzer-ID-Summenpreisen gruppieren

+-------------+---------------+-------------+
| ancestor_id | descendant_id | path_length |
+-------------+---------------+-------------+
|           1 |             1 |           0 |
|           1 |             2 |           1 |
|           1 |             3 |           1 |
|           1 |             4 |           2 |
|           1 |             5 |           2 |
|           1 |             6 |           2 |
|           1 |             7 |           3 |
|           2 |             2 |           0 |
|           2 |             4 |           1 |
|           2 |             5 |           1 |
|           2 |             7 |           2 |
|           3 |             3 |           0 |
|           3 |             6 |           1 |
|           4 |             4 |           0 |
|           4 |             7 |           1 |
|           5 |             5 |           0 |
|           6 |             6 |           0 |
|           7 |             7 |           0 |
+-------------+---------------+-------------+

Ich habe gefragt, ob alle Kinder zusammengezählt werden sollen

select 
sum(b.price)

from webineh_prefix_nodes_paths_tmp a

    join webineh_prefix_nodes_tmp b on (b.userid = a.descendant_id)

where a.ancestor_id = 1 

dies funktioniert gut, aber die Gesamtsumme Eltern 1

Ich muss das folgende Ergebnis für child direct anzeigen (2,3)

 +----------+------------+-
    | userid   |    total   |
    +----------+------------+
    | 2        |    80      |
    | 3        |    40      |
    +----------+------------+

auch in sqlfiddle meine frage erstellenhttp: //sqlfiddle.com/#! 9 / 9415ed / 2

Antworten auf die Frage(4)

Ihre Antwort auf die Frage