Einzelnen Beitrag anzeigen

Morphie

Registriert seit: 27. Apr 2008
Ort: Rahden
630 Beiträge
 
#1

Hierarchie in Datenbank und DataSet abbilden

  Alt 20. Jun 2013, 10:32
Datenbank: Firebird • Version: 2.5 • Zugriff über: FireDAC
Ich habe eine Tabelle, die mit sich selbst verknüpft ist:
Code:
CREATE TABLE BELEGPOSITION (
  ID                       BIGINT NOT NULL,
  PARENTID                 BIGINT,
  OZ                       VARCHAR(20) NOT NULL,
  /* Schlüssel */
  PRIMARY KEY (ID),
  /* Fremdschlüssel */
  CONSTRAINT "BELEGPOSITION-BELEGPOSITION"
    FOREIGN KEY (PARENTID)
    REFERENCES BELEGPOSITION(ID)
    ON DELETE NO ACTION
    ON UPDATE NO ACTION
);
(in der Praxis sind es natürlich weitaus mehr Spalten)

Die ID ist also der Primärschlüssel (AutoInc), ParentID ist der Verweis zur Eltern-Position.
Das ganze hat den Sinn, hierarchische Positionen aufbauen zu können (z.B. im Baugewerben für Lose und Titel, oder für Unterpositionen, Stücklisten usw.)

Die OZ (Ordnungszahl) bestimmt den letzten Teil der Positionsnummer aus der aktuellen Hierarchie-Ebene:
1. Position (Hauptposition), OZ: 01, Positionsnr: 01
2. Position (Unterposition), OZ: 01, Positionsnr: 01.01
3. Position (Unterposition), OZ: 02, Positionsnr: 01.02
4. Position (Unter-Unterposition), OZ: 01, Positionsnr: 01.02.01
...

Ich muss mich jetzt entscheiden, wie ich die Positionsnr in meinem Programm dynamisch aufbaue. Die Ergebnismenge soll später in einem Grid dargestellt werden.

Mir fallen dabei mehrere Lösungen ein:
1. ein weiteres InternalCalcField in meinem DataSet, welches die Positionsnr zusammenbaut. (das wäre mein Favorit)
Problem: Wie komme ich performant an die Parent-Position?

2. Recursive CTEs
Problem: soweit mir bekannt, sind diese aber read-only, richtig?

3. ein entsprechendes Grid verwenden (DevExpress TreeList), welches mir automatisch meine Hirarchie zusammenbaut (das habe ich sowieso vor)
Dann könnte ich im OnGetText (oder so ähnlich) den Inhalt der Spalte zusammenbauen.
Nachteil: Ich vermische GUI und Daten wieder... Besser wäre wohl, wenn die Daten so schon im DataSet vorliegen.

Wie würdet ihr das machen? Habt ihr andere Ideen?
  Mit Zitat antworten Zitat