Treetable (rekursive Funktion) aufbauen von Datenbank

B

beta20

Top Contributor
Hallo zusammen,

Ich habe die folgende Klasse (Entity):

Java:
@Entity
@Table(name = "branch", indexes = { @Index(columnList = "branch_id, id_hash, status, delete_flag") })
public class Branch implements Serializable {

    private static final long serialVersionUID = 1L;

    public static final Long NO_ID = Long.valueOf(0);

    @Id
    @GeneratedValue(generator = "branch_id_seq", strategy = AUTO)
    @SequenceGenerator(name = "branch_id_seq", sequenceName = "branch_branch_id_seq", allocationSize = 1)
    @Column(name = "branch_id", nullable = false)
    private Long id = NO_ID;

    // ID Hash (für URL)
    @NotNull
    @Size(max = Constants.SIZE_MAX_STRING)
    @Column(name = "id_hash", length = Constants.SIZE_MAX_STRING, nullable = false)
    private String idHash;

    // Status des Beitrags
    @NotNull(message = "Bitte ein Status angeben")
    @Size(max = Constants.SIZE_MAX_STRING)
    @Column(name = "status", length = Constants.SIZE_MAX_STRING, nullable = false)
    private String status = BranchStatus.ACTIVE.toString();

    public enum BranchStatus {
        ACTIVE, // Aktiv
        INACTIVE, // Inaktiv
        DRAFT, // Entwurf
        DECLINE, // Gesperrt
    }

    // Level
    @Column(name = "tree_level", nullable = true)
    private int treeLevel = 0;
   
    // Parent
    @ManyToOne
    @JoinColumn(name = "parent_branch_fk")
    private Branch parentBranch;
   
    // Children
    @OneToMany(mappedBy = "parentBranch", cascade = { PERSIST, MERGE, REMOVE, REFRESH })
    @LazyCollection(LazyCollectionOption.FALSE)
    private List<Branch> childrenBranch;

Nun würde ich gerne meine Hierarchy aufbauen.
Also Root (bzw. oberste Ebene können mehrere sein)...
Ich möchte allerdings nur diese, die aden Status ACTIVE haben....

Frage:
1) Soll ich zunächst alle Branch (die aktiv sind) mir aus der Datenbank holen und dann die Hierarchy aufbauen?
2) Wie sieht die rekursive Methode aus?

Wichtig:
Ich verwende Primefaces und muss die "Branch" Entity dann noch "umwandeln" in ein TreeNode Objekt....

Hier ein Ansatz der Methode, was aber nicht 100% funktioniert...

Java:
public void init() {
        Branch root = new Branch(); // instead get root object from database
        rootNode = newNodeWithChildren(root, null);
    }
   
   
   
     /**
     *  recursive function that returns a new node with its children
    */
    public TreeNode newNodeWithChildren(Branch ttParent, TreeNode parent){
         TreeNode newNode= new DefaultTreeNode(ttParent, parent);
         for (Branch tt : ttParent.getChildrenBranch()){
              TreeNode newNode2= newNodeWithChildren(tt, newNode);
         }
         return newNode;
    }

Danke für jede Hilfe..
 
MoxxiManagarm

MoxxiManagarm

Top Contributor
Müsste er nicht den erstellten Node nicht noch dem Parent hinzufügen? Wäre mein spontaner Gedanke.

Java:
public TreeNode newNodeWithChildren(Branch ttParent, TreeNode parent){
         TreeNode newNode= new DefaultTreeNode(ttParent, parent);
         List<TreeNode> children = newNode.getChildren();

         for (Branch childBranch : ttParent.getChildrenBranch()){
              children.add(newNodeWithChildren(childBranch, newNode));
         }

         return newNode;
    }
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
F TreeTable Java Basics - Anfänger-Themen 5
veryck Methoden Rekursive Methoden mit Rückgabeparameter Java Basics - Anfänger-Themen 9
macle Rekursive String Methode, Gerade Zahlen rausfiltern Java Basics - Anfänger-Themen 10
M Rekursive Prüfung ob ein Array sortiert ist... Java Basics - Anfänger-Themen 4
J Rekursive swapArray Methode Java Basics - Anfänger-Themen 69
D Rekursive Methode Java Basics - Anfänger-Themen 8
R Methoden rekursive Methoden Java Basics - Anfänger-Themen 6
O Quersumme rekursive Methode Java Basics - Anfänger-Themen 3
M Rekursive Methode Programmieren Java Basics - Anfänger-Themen 3
J rekursive Methode Java Basics - Anfänger-Themen 26
M rekursive division/0 mit exception Java Basics - Anfänger-Themen 18
J Rekursive Methode - Ziffern einer Zahl ausgeben Java Basics - Anfänger-Themen 2
M Rekursive Dateiliste erstellen mit Dateiendung(en) ?? Java Basics - Anfänger-Themen 4
S Rekursive Methode Java Basics - Anfänger-Themen 8
O Rekursive Methode Java Basics - Anfänger-Themen 4
V Methoden Rekursive Methode mit String als Rückgabe Java Basics - Anfänger-Themen 7
K Rekursive Methode Java Basics - Anfänger-Themen 1
K Rekursive Methode für Fakultät mit BigInteger Java Basics - Anfänger-Themen 10
L Rekursive Methode a * b berechnen Java Basics - Anfänger-Themen 2
L Rekursive Methode zur Berechnung der Potenz q hoch p Java Basics - Anfänger-Themen 17
J Methoden Rekursive Return Methode Java Basics - Anfänger-Themen 2
G Harmonische Rekursive Folge Java Basics - Anfänger-Themen 3
T Stack Overflow - Rekursive Fibonacci Java Basics - Anfänger-Themen 10
B Datentypen Suchbaum - Rekursive Ausgabe Java Basics - Anfänger-Themen 1
P Methoden Rekursive Methode für Potenzen Java Basics - Anfänger-Themen 2
M Methoden Binäre Suche als rekursive Variante Java Basics - Anfänger-Themen 5
B Rekursive Algorithmus schreiben Java Basics - Anfänger-Themen 8
S Eine rekursive Lösung Java Basics - Anfänger-Themen 4
S Int zu Hexadezimal - Rekursive Methode Java Basics - Anfänger-Themen 2
M Rekursive Suche in einem Feld Java Basics - Anfänger-Themen 11
N Rekursive Addition mit Scanner Java Basics - Anfänger-Themen 12
shiroX OOP Rekursive und Iterative Definition Java Basics - Anfänger-Themen 2
B Methoden Rekursive Methoden Java Basics - Anfänger-Themen 2
T Iterative Pi Berechnung in Rekursive Java Basics - Anfänger-Themen 2
C rekursive methode Java Basics - Anfänger-Themen 2
D Methoden Rekursive Methoden Java Basics - Anfänger-Themen 13
R rekursive Methode funktioniert nicht Java Basics - Anfänger-Themen 4
M Stürzen alle Rekursive Methoden irgendwann ab? Java Basics - Anfänger-Themen 11
D Primzahlen und Rekursive Liste Java Basics - Anfänger-Themen 29
R Rekursive Methode, Files finden Java Basics - Anfänger-Themen 2
S rekursive folge verbessern Java Basics - Anfänger-Themen 2
C rekursive Methode verstehe nicht! Java Basics - Anfänger-Themen 3
S Methoden rekursive Methode funktioniert nicht Java Basics - Anfänger-Themen 4
E Rekursive Methode Java Basics - Anfänger-Themen 3
N Methoden Rekursive Fibonaccizahlen mit Array Java Basics - Anfänger-Themen 2
R Rekursive Ausgabe eines Binärbaums Java Basics - Anfänger-Themen 4
J Methoden Rekursive Potenz ohne Math.Pow() Java Basics - Anfänger-Themen 9
A Rekursive Methode in Iterative umwandeln Java Basics - Anfänger-Themen 6
S Labyrith Rekursive Wegsuche Java Basics - Anfänger-Themen 4
C Rekursive Methode - Ziffern in Zahl Java Basics - Anfänger-Themen 33
U Dezimal zu Hexadezimal rekursive Funktion Java Basics - Anfänger-Themen 8
M rekursive Funktion zur Berechnung der Spiegelzahl Java Basics - Anfänger-Themen 7
L iterative und rekursive Folge Java Basics - Anfänger-Themen 20
G Rekursive Methode Java Basics - Anfänger-Themen 3
A rekursive Listen in Java? Java Basics - Anfänger-Themen 5
B OOP Einfach verkettete Liste - rekursive Methoden Java Basics - Anfänger-Themen 1
E Rekursive Methode mit Zufallsarray Java Basics - Anfänger-Themen 6
E Rekursive Methode Java Basics - Anfänger-Themen 18
U Rekursive lösung von pascal dreieck Java Basics - Anfänger-Themen 11
M Rekursive Methode - wo ist der Fehler? Java Basics - Anfänger-Themen 4
J rekursive methode Java Basics - Anfänger-Themen 6
H ScrollBar inaktiv / Rekursive Methode Java Basics - Anfänger-Themen 4
J Rekursive Methode Java Basics - Anfänger-Themen 11
G Rekursive Methode Java Basics - Anfänger-Themen 5
N Rekursive Berechnung der Höhe eines binären Baumes Java Basics - Anfänger-Themen 4
K Rekursive Methoden Java Basics - Anfänger-Themen 15
K Rekursive Funktion (Verständnissfrage) Java Basics - Anfänger-Themen 5
S Rekursive Bruch potenzierung Java Basics - Anfänger-Themen 2
D rekursive Summenberechnung Java Basics - Anfänger-Themen 8
J Rekursive Methode: Fakultaet berechnen Java Basics - Anfänger-Themen 5
E Rekursive definierten Folge Java Basics - Anfänger-Themen 10
A HILFE! Rekursive Funktion Java Basics - Anfänger-Themen 20
kulturfenster rekursive Binaere Suche Java Basics - Anfänger-Themen 12
F Rekursive Aufrufe, Parameterübergabe, call by reference Java Basics - Anfänger-Themen 3
G Rekursive Berechnung von n über k schlägt fehl Java Basics - Anfänger-Themen 5
B Rekursive & schreiben im ArrayList Java Basics - Anfänger-Themen 2
J Rekursive Fkt. Java Basics - Anfänger-Themen 2
A Rekursive Dateisuche Java Basics - Anfänger-Themen 12
K rekursive Funktion mit mehreren Parametern Java Basics - Anfänger-Themen 5
G rekursive Methode Java Basics - Anfänger-Themen 3
N rekursive Beispiele Java Basics - Anfänger-Themen 3
G rekursive u iterative Methode Java Basics - Anfänger-Themen 8
G Rekursive Methode Java Basics - Anfänger-Themen 7
ven000m Rekursive Funktionen - Frage Java Basics - Anfänger-Themen 16
D rekursive ausgabe einer zahl Java Basics - Anfänger-Themen 14
S Rekursive Funktionen in imperative Funktionen umwandeln Java Basics - Anfänger-Themen 2
M Rekursive Binärsuche Java Basics - Anfänger-Themen 6
S rekursive methoden Java Basics - Anfänger-Themen 5
Tino1993 Ellipse über draw Funktion ohne spur wandern lassen Java Basics - Anfänger-Themen 6
X Ackermannsche Funktion Java Basics - Anfänger-Themen 32
F Arrays: Mathematische Funktion Java Basics - Anfänger-Themen 19
P Dezimal zu Hexadezimalzahl Funktion Java Basics - Anfänger-Themen 5
S Verwenden von throw Exception an der Funktion Java Basics - Anfänger-Themen 2
M Arrays in Funktion Kopieren und Bearbeiten Java Basics - Anfänger-Themen 4
B Funktion mit mehreren Rückgabewerten aka Prozeduren? Java Basics - Anfänger-Themen 12
J Dynamisches Array durch split()-Funktion? Java Basics - Anfänger-Themen 3
D Funktion nur 1 Rueckgabewert Java Basics - Anfänger-Themen 9
M Wie lang eine Funktion/Methode? Java Basics - Anfänger-Themen 51
N den inhalt eines array per funktion ausgeben Java Basics - Anfänger-Themen 8
R Ackermann Funktion Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Anzeige


Oben