AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Hierarchie in Datenbank und DataSet abbilden

Hierarchie in Datenbank und DataSet abbilden

Ein Thema von Morphie · begonnen am 20. Jun 2013 · letzter Beitrag vom 20. Jun 2013
 
Morphie

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

Hierarchie in Datenbank und DataSet abbilden

  Alt 20. Jun 2013, 09: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
 

Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 10:51 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz