AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken FreePascal Können zwei Tabellen gegenseitig zu einander in Beziehung stehen?
Thema durchsuchen
Ansicht
Themen-Optionen

Können zwei Tabellen gegenseitig zu einander in Beziehung stehen?

Ein Thema von AlexII · begonnen am 12. Mai 2015 · letzter Beitrag vom 14. Mai 2015
Antwort Antwort
Seite 1 von 3  1 23      
AlexII

Registriert seit: 28. Apr 2008
1.717 Beiträge
 
FreePascal / Lazarus
 
#1

Können zwei Tabellen gegenseitig zu einander in Beziehung stehen?

  Alt 12. Mai 2015, 13:37
Datenbank: SQLite • Version: 3 • Zugriff über: SQLQuery
Hallo,

können zwei Tabellen (A, B) gegenseitig zu einander in Beziehung stehen? Ein FK der Tabelle A zeig auf die Tabelle B, und der FK der Tabelle B zeigt auf die Tabelle A? Oder ist das keine gute Idee?

Danke!
Bin Hobbyprogrammierer! Meine Fragen beziehen sich meistens auf Lazarus!

Geändert von AlexII (12. Mai 2015 um 13:40 Uhr)
  Mit Zitat antworten Zitat
Dejan Vu
(Gast)

n/a Beiträge
 
#2

AW: Können zwei Tabellen gegenseitig zu einander in Beziehung stehen?

  Alt 12. Mai 2015, 13:44
Kommt drauf an. Normalerweise ist das ein Indiz, das etwas am Design faul ist, muss aber nicht. Nenn mal ein konkretes Beispiel.
  Mit Zitat antworten Zitat
AlexII

Registriert seit: 28. Apr 2008
1.717 Beiträge
 
FreePascal / Lazarus
 
#3

AW: Können zwei Tabellen gegenseitig zu einander in Beziehung stehen?

  Alt 12. Mai 2015, 13:50
Tabelle Alarm
---------
id
alarmdatetime
fk_jobid


Tabelle Job
---------
id
job
fk_alarmid


Nun ist es so, mehrere Alarme können auf einen Job verweisen dazu der FK. Und den FK in der Tabelle Job brauche ich um alle Alarme aus der Tabelle Alarm zu löschen falls ein Job gelöscht wird.
Bin Hobbyprogrammierer! Meine Fragen beziehen sich meistens auf Lazarus!
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.858 Beiträge
 
Delphi 11 Alexandria
 
#4

AW: Können zwei Tabellen gegenseitig zu einander in Beziehung stehen?

  Alt 12. Mai 2015, 13:54
Ich würde hier mit einer Zwischentabelle arbeiten.
Aber die Rückverknüpfung ist eigentlich nicht notwendig

Delete from alarm a where a.<pk> in ( select j.<pk> from job j where j.<fk> = a.<pk>);
Markus Kinzler
  Mit Zitat antworten Zitat
AlexII

Registriert seit: 28. Apr 2008
1.717 Beiträge
 
FreePascal / Lazarus
 
#5

AW: Können zwei Tabellen gegenseitig zu einander in Beziehung stehen?

  Alt 12. Mai 2015, 13:57
Ok...
Bin Hobbyprogrammierer! Meine Fragen beziehen sich meistens auf Lazarus!
  Mit Zitat antworten Zitat
RoadR69

Registriert seit: 7. Nov 2013
17 Beiträge
 
Delphi 10 Seattle Professional
 
#6

AW: Können zwei Tabellen gegenseitig zu einander in Beziehung stehen?

  Alt 12. Mai 2015, 14:01
mehrere Alarme können auf einen Job verweisen und wenn ich einen Job lösche, muss ich ebenfalls zugehörige Alarme löschen. Ist das DB-technisch gesehen nicht die gleiche Beziehung, will heißen, der FK in Jobs, der ja nur auf ein Elemant in Alarm zeigen könnte ist eh überflüssig?
  Mit Zitat antworten Zitat
jobo

Registriert seit: 29. Nov 2010
3.072 Beiträge
 
Delphi 2010 Enterprise
 
#7

AW: Können zwei Tabellen gegenseitig zu einander in Beziehung stehen?

  Alt 12. Mai 2015, 14:08
der FK in Jobs, der ja nur auf ein Elemant in Alarm zeigen könnte ist eh überflüssig?
Wenn dieser FK auf den einen Alarm keine spezielle Semantik hat, ist er mehr als überflüssig. Die Abhängigkeit kann aus den FK in Alarm gebildet werden.

Angenommen, man hätte sowas wie "Roter Alarm", der pro Job nur einmal vorkommen kann und dessen Eigenart unabhängig von den Merkmalen der gesamten Alarmliste je Job ist, könnte man sowas vielleicht gebrauchen.
Gruß, Jo
  Mit Zitat antworten Zitat
Dejan Vu
(Gast)

n/a Beiträge
 
#8

AW: Können zwei Tabellen gegenseitig zu einander in Beziehung stehen?

  Alt 12. Mai 2015, 14:12
Also pro Job mehrere Alarme? Ok, also der FK in der Alarmtabelle auf die Jobs. Klar.
Aber wozu hat dann ein Job eine Alarm-FK? Zum Löschen *aller* Alarme, wo die FK_AlarmID doch nur auf einen Alarm zeigt? Verstehe ich nicht.

Löschen eines Jobs 'JID'
Code:
delete from Alarme where FK_JobID='JID'
delete from Job where ID = 'JID'
Hab ich da was falsch verstanden?
  Mit Zitat antworten Zitat
AlexII

Registriert seit: 28. Apr 2008
1.717 Beiträge
 
FreePascal / Lazarus
 
#9

AW: Können zwei Tabellen gegenseitig zu einander in Beziehung stehen?

  Alt 12. Mai 2015, 14:18
Ne, ist schon richtig so, alles richtig verstanden... danke!
Bin Hobbyprogrammierer! Meine Fragen beziehen sich meistens auf Lazarus!
  Mit Zitat antworten Zitat
khh

Registriert seit: 18. Apr 2008
Ort: Südbaden
1.929 Beiträge
 
FreePascal / Lazarus
 
#10

AW: Können zwei Tabellen gegenseitig zu einander in Beziehung stehen?

  Alt 12. Mai 2015, 15:51
eine gute Gelegenheit sich mal hiermit zu beschäftigen
https://www.hdm-stuttgart.de/~rieker...kelz/chap4.htm
Karl-Heinz
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 3  1 23      


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 20:36 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