Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Foreign Key Referenzierungsproblem (https://www.delphipraxis.net/72626-foreign-key-referenzierungsproblem.html)

dataspider 4. Jul 2006 09:33

Datenbank: Firebird • Version: 1.53 • Zugriff über: IBO, IBExpert

Foreign Key Referenzierungsproblem
 
Hallo,

ich habe mir wohl selbst ein kleines Ei gelegt.
Ich habe die Tabellen Mitarbeiter und Mandant.
Tabelle Mandant hat das Feld Mitarbeiter_id und die Tabelle Mitarbeiter das Feld Mandant_id.
Beide Beziehungen sind über Foreign Keys verknüpft.

Jetzt erzeuge ich eine leere DB und merke, dass ich weder in Mandant noch in Mitarbeiter Daten anlegen kann, da von der anderen Tabelle der Record mit PK 0 fehlt (Circulus vitiosus). :angel2:

Fehler:
(violation of FOREIGN KEY constraint "MAMANDANT_FK" on table "MITARBEITER)

Jetzt kann ich natürlich mal die Beziehung auflösen und dann wieder herstellen.
Aber vielleicht kann mir ein Profi sagen, wie ich das Ganze handeln sollte.
Muss ich solche sich gegenseitig referenzierenden Beziehungen vermeiden oder gibt es eine saubere Lösung?

Dass das DB - Design hier nicht sauber ist, ist mir klar. Mir geht es jetzt nur ums Prinzip.
Ich muss auch zu meiner Verteidigung noch sagen, dass die 2 Beziehungen unterschiedliche Hintergründe haben.
Mandant_id in Mitarbeiter referenziert die Zugehörigkeit des Mitarbeiters ztur Firma.
Mitarbeiter_id im Mandant referenziert den verantwirtlichen Vertriebsmitarbeiter der Firma.
In Zukunft werde ich das sicher in seperaten Tabellen verwalten.

Danke, Frank

mkinzler 4. Jul 2006 09:39

Re: Foreign Key Referenzierungsproblem
 
Ich würde einfach die Zuordnung des zuständigen Vertriebmitarbeiter in eine Zurdnungstabelle auslagern, hat auch den Vorteil das mehrere Mitarbeiter zugeordnet werden können.

dataspider 4. Jul 2006 10:50

Re: Foreign Key Referenzierungsproblem
 
Zitat:

Zitat von mkinzler
Ich würde einfach die Zuordnung des zuständigen Vertriebmitarbeiter in eine Zurdnungstabelle auslagern, hat auch den Vorteil das mehrere Mitarbeiter zugeordnet werden können.

Wenn ich dich richtig verstehe, sind solche Kreuzbeziehungen also nicht zulässig ?!
Somit werde ich diese vermeiden bzw. auflösen.

Danke

Frank

mkinzler 4. Jul 2006 10:52

Re: Foreign Key Referenzierungsproblem
 
Du könntest natürlich auch NULL für das Referenzfeld zulassen, besser finde ich aber die Lösung über eigene Tabelle.

dataspider 4. Jul 2006 11:18

Re: Foreign Key Referenzierungsproblem
 
Zitat:

Zitat von mkinzler
Du könntest natürlich auch NULL für das Referenzfeld zulassen, besser finde ich aber die Lösung über eigene Tabelle.

Das hatte ich probiert. Aber sobald du einen Foreign Key zum Feld anlegst, wird null nicht mehr akzeptiert.
Zumindest meckerte er auch bei meinen Tests.

Frank


Alle Zeitangaben in WEZ +1. Es ist jetzt 02:47 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-2025 by Thomas Breitkreuz