![]() |
Datenbank: Firebird • Version: 2.1 • Zugriff über: IB
TreeView dynamisch aus einer Datenbank füllen
Hallo zusammen,
ich schreibe gerade an einem Programm, wo ich gerne einen TTreeView dynmaisch aus einer Datenbank füllen möchte. Ich habe dazu zwei Tabellen. Die eine Tabelle heißt Category und die andere heißt FAQ. Strukture von Tabelle Category : (Feld ID ist autoinc)
SQL-Code:
Strukture von Tabelle FAQ : (Feld ID ist autoinc)
CREATE TABLE CATEGORY (
ID INTEGER NOT NULL, PARENTID INTEGER, DESCRIPTION VARCHAR(50) NOT NULL, "SEQUENCE" INTEGER NOT NULL );
SQL-Code:
Im Moment fülle ich den TreeView mit diesen beiden Funktionen :
CREATE TABLE FAQ (
ID INTEGER NOT NULL, CATID INTEGER NOT NULL, HEADER VARCHAR(255) NOT NULL, CODE BLOB SUB_TYPE 0 SEGMENT SIZE 120 NOT NULL, DESCRIPTION BLOB SUB_TYPE 0 SEGMENT SIZE 120 NOT NULL, NOTES BLOB SUB_TYPE 0 SEGMENT SIZE 120 NOT NULL );
Delphi-Quellcode:
Derzeit sieht meine TreeView so aus :
procedure TMainForm.FillTreeView;
var tmpNode : TNodeArray; I, Count : integer; begin Count := 0; TV_Category.Items.Clear; with IBQuery do begin SQL.Clear; SQL.Text := 'SELECT * FROM CATEGORY WHERE PARENTID=0;'; Open; Active := true; while not EOF do begin Setlength(tmpNode, count + 1); tmpNode[Count] := TV_Category.Items.Add(nil, Fields[2].AsString); Inc(Count); next; end; Active := false; for I := 0 to length(tmpNode) - 1 do begin SQL.Clear; SQL.Text := Format('SELECT * FROM CATEGORY WHERE parentid=%d ORDER BY description;', [i + 1]); Open; Active := true; while not EOF do begin FillCodeEntries(TV_Category.Items.AddChild(tmpNode[i], Fields[2].AsString), Fields[0].AsInteger); next; end; Active := false; end; end; end; procedure TMainForm.FillCodeEntries(aNode: TTreeNode; catid: integer); var tmpNode : TTreeNode; begin with IBTmpQuery do begin SQL.Clear; SQL.Text := Format('SELECT * FROM faq WHERE catid=''%d'' ORDER BY header;', [catid]); Open; Active := true; while not EOF do begin tmpNode := TV_Category.Items.AddChild(aNode, Fields[2].AsString); tmpNode.ImageIndex := 2; tmpNode.SelectedIndex := 2; next; end; Active := false; end; end; Zitat:
Edit: Ansicht der Baumstruktur geändert. |
Re: TreeView dynamisch aus einer Datenbank füllen
*push* Hat keiner eine Idee ? Oder geht es mit meiner Tabelle nicht ? *push*
|
Re: TreeView dynamisch aus einer Datenbank füllen
Also ich würde hergehen, und mir zu jeder Kategorie die FAQ-Einträge dazujoinen...
also:
SQL-Code:
Damit hast Du alle Daten sortiert nach Ebenen in einem Dataset.
SELECT c.*, f.*
FROM Category c LEFT JOIN FAQ f ON f.CatdId = c.ID ORDER BY c.PARENTID DESC, c.DESCRIPTION, f.HEADER Das heisst, Du brauchst da nix rekursiv zu machen, und Du brauchst vor allem nicht für jede Ebene ein Statement abzufeuern. Du läufst einmal durch das Dataset durch, legst pro Eintrag einen Node an (wenn es den Parent noch nicht gibt legst Du den neuen Node in einem temporären Array ab und hängst ihn dann ein, sobald Du den Parent angelegt hast). Du hast auch automatisch alle FAQ-Header dazu. |
Re: TreeView dynamisch aus einer Datenbank füllen
Huhu,
Also ein Treeview in einer DB zu speichern ist grundsätzlich "recht einfach" (ok ich hab das bestimmt schon 5-6 mal gemacht :-). Am einfachsten ist es Alles in einer TBL zu speichern. mit Beispielsweise folgendem Aufbau: Nummer,Ebene,Bezeichnung; Du machst eine Proc, die RekursivFähig ist!!! <-- das ist der entscheidente Punkt. Hier hab ich mal n kleines Beispiel zusmmen gestellt. Ist aber nur Schematisch dargestellt.
Delphi-Quellcode:
Function TreeLoad(TR : ttreeview;AbDatensatz,Ebene : Integer) : Integer; // Gibt die Nr zurück bis wohin diesr Ausruf gearbeitet hat
Begin // Daten suchen Q1 := TQuery.Create; .. Q1.SQL.Text := Select * From TBL where Nr >= AbDatensatz order by Nr; while not Q1.eof do Begin if Q1.FieldByName('Ebene').asInteger = Ebene then Tr.Items.Add() // Node Erzeugen else Begin if Q1.FieldByName('Ebene').asInteger > Ebene then Begin BisNr := TreeLoad(TR,Q1.FieldByName('Nr').asInteger,Q1.FieldByName('Ebene').asInteger); // mit der Nächsten Ebene Aufrufen Q1.SQL.Text := Select * From TBL where Nr >= BisNr order by Nr; End else Q1.Prior; End; Q1.Next; end; result := Q1.FieldByName('Nr').asInteger; end; So habe ich das Problem gelöst.Evebtuell hilft es dir ja ein bisschen weiter. |
Re: TreeView dynamisch aus einer Datenbank füllen
Hallo Sebastian,
danke erstmal für Deine Antwort. Zitat:
|
Re: TreeView dynamisch aus einer Datenbank füllen
Hi,
Also ich habe es wie oben Beschrieben ganz gut lösen können und so kannst du bis zu N-Unterebenen anlegen. Ich hab auch lange gesucht aber ohne Rekus hab ichs leider nicht hinbekommen. mfg Jens |
Re: TreeView dynamisch aus einer Datenbank füllen
Hallo Pro_RJ,
du legst die Ebenen aber vorher fest. So wie ich das Verstanden habe soll die Ebenen aber dynamisch Erweitert werden. Bis bald Chemiker |
Re: TreeView dynamisch aus einer Datenbank füllen
Nein eigentlich nicht.
beispiel: Ebene 0 | ____|->Ebene 1 _______ | ________|-> Ebene 2 ________|-> Ebene 3 ___________|-> Ebene 4 ________|-> Ebene 3 ________|-> Ebene 3 ____|->Ebene 2 ____|->Ebene 2 |->Ebene 1 ________|->Ebene 2 ________|->Ebene 2 ____|->Ebene 1 ________|->A3A ____|->A3B ____|->A3C ____|->A3D ____|->Ebene 1 Jeder Unterpunkt ist eine Ebene höher |
Re: TreeView dynamisch aus einer Datenbank füllen
Hallo,
ok, ich will nicht zu viel über Datenbanken schreiben, nur soviel man kann so was auch über eine entsprechende Sortierung der Datensätze erreichen und schreibt die Knoten einfach hintereinander. Nur zu viele Datensätze sollten es nicht werden, dann wird das Eintragen doch sehr langwierig. Bis bald Chemiker |
Re: TreeView dynamisch aus einer Datenbank füllen
naja also ein Baumdiagramm mit ca 1000 Nodes braucht bei mir ca 1-1,5 Secunden.
Es sollte auch nur ein Gedankenanstoß sein |
Re: TreeView dynamisch aus einer Datenbank füllen
Ich komme irgendwie nicht weiter. Entweder lande ich in einer Endlosschleife oder ich habe nur eine andere Version von meinem Vorgehen wie aus Beitrag 1. Ich blicke bei euren Vorschlägen nicht ganz durch. Könnte mann mir das nochmal bitte genauer erklären. Anscheinend sehe ich den Wald vor lauter Bäumen nicht.
In diesem Sinne gute Nacht und bis in ein paar Stunden. |
Re: TreeView dynamisch aus einer Datenbank füllen
Hallo zusammen,
ich habe jetzt eine Lösung gebaut, die aufbaut auf den Weg von Sebastian (Phoenix). ![]() |
Alle Zeitangaben in WEZ +1. Es ist jetzt 22:46 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz