Delphi-PRAXiS
Seite 2 von 2     12   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Hilfe bei N:M Beziehung (https://www.delphipraxis.net/116966-hilfe-bei-n-m-beziehung.html)

Cosamia 10. Jul 2008 07:27

Re: Hilfe bei N:M Beziehung
 
Ja, kann sie. Ich will den Aufwand beim Erstellen von Teilaufgaben etwas eingrenzen.

DeddyH 10. Jul 2008 08:02

Re: Hilfe bei N:M Beziehung
 
Zitat:

Zitat von Cosamia
Die Zuordnungstabelle besteht aus den zwei Fremdschlüsseln und einer eigenen ID.

Wieso nicht aus einem aus den beiden Fremdschlüsseln zusammengesetzten PK? So mache zumindest ich das immer, wenn keine weiteren Daten benötigt werden.

marabu 10. Jul 2008 08:18

Re: Hilfe bei N:M Beziehung
 
Moin,

ich nehme die Aussage M:N als gegeben an. Generell gilt beim Übergang vom E/R-Modell zum Datenmodell: Aus Entitäten (Singular: Teilaufgabe, Anforderung) werden Tabellen (Plural: Teilaufgaben, Anforderungen). Die Tabelle mit den Zuordnungen würde ich nicht TEMP nennen. Wenn es sich um einen Beziehungsdatentyp handeln würde, dann wäre ein eigener ID korrekt, bei einer reinen Zuordnung (ohne eigene Attribute) verzichtet man darauf, da ein solcher Schlüssel nur unnötigen Verwaltungsaufwand mit sich bringt. Der Optimizer benutzt diesen Schlüssel nie - und würde er es tun, dann nur um eine relativ teure Schlüsselabbildung durchzuführen.

Das Grid kann wie oben beschrieben über den MasterSource-Mechanismus bedient werden. Die Verknüpfung geschieht über das Schlüsselpaar master.id = detail.anforderungen_id, wobei master = anforderungen und detail der folgende JOIN ist:

SQL-Code:
SELECT t.*, z.anforderungen_id
FROM temp z
JOIN teilaufgaben t ON z.teilaufgaben_id = t.id
Freundliche Grüße


Alle Zeitangaben in WEZ +1. Es ist jetzt 20:02 Uhr.
Seite 2 von 2     12   

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