AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Zwei Tabellen mit einander Verknüpfen

Zwei Tabellen mit einander Verknüpfen

Ein Thema von Luckie · begonnen am 3. Feb 2005 · letzter Beitrag vom 5. Feb 2005
Antwort Antwort
Seite 2 von 4     12 34   
Benutzerbild von mikhal
mikhal

Registriert seit: 11. Sep 2003
Ort: Linz am Rhein
796 Beiträge
 
Delphi 11 Alexandria
 
#11

Re: Zwei Tabellen mit einander Verknüpfen

  Alt 3. Feb 2005, 15:32
Zitat:
Wobei ein Lieferant auch mehrere Produkte liefern kann
Deine Fragestellung läßt aber nur eine n:m-Verknüpfung zu!

[edit] Ist eine Frage der Sichtweise und wie man ein Projekt erweitern möchte...[/edit]

Grüße
Mikhal
Michael Kraemer
Computer erleichtern die Arbeit...
...und die Erde ist eine Scheibe!
  Mit Zitat antworten Zitat
Zottel
(Gast)

n/a Beiträge
 
#12

Re: Zwei Tabellen mit einander Verknüpfen

  Alt 3. Feb 2005, 15:35
hmmm....
ein lieferant = 1
mehrere Produkte = n

ergibt 1:n

wo ist da eine n:m verknüpfung?

nur zum verständnis gefragt. vielleicht sehe ich das bisher auch aus der falschen perspektive.
danke
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#13

Re: Zwei Tabellen mit einander Verknüpfen

  Alt 3. Feb 2005, 15:36
Ja:

Lieferant1: Eis und Schokolade
Lieferant2: Brot und Eier
Lieferant3: Gummihandschuhe und Seife

Aber ein vierter Lieferant kann jetzt keine Schokolade und Eier liefern. Ein Produkt kann immer nur von einem Lieferanten bezogen werden, aber ein Lieferant kann mehrere Produkte liefern. So war es gemeint.

Oh Mann, ich habe gerade erst angefangen und bekomme schon ein Knoten in mein Hirn.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Zottel
(Gast)

n/a Beiträge
 
#14

Re: Zwei Tabellen mit einander Verknüpfen

  Alt 3. Feb 2005, 15:38
imho reicht dann dein letzter aufbau der tabellen vollkommen aus.
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#15

Re: Zwei Tabellen mit einander Verknüpfen

  Alt 3. Feb 2005, 15:40
Es ist der Begriff "Fremdschlüssel" gefallen. Ist das nur eine Bezeichnung von euch oder muss ich in der Tabellen dem Feld diese Eigenschaft zuweisen?
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Benutzerbild von mikhal
mikhal

Registriert seit: 11. Sep 2003
Ort: Linz am Rhein
796 Beiträge
 
Delphi 11 Alexandria
 
#16

Re: Zwei Tabellen mit einander Verknüpfen

  Alt 3. Feb 2005, 15:43
Erfahrung: Ich habe noch kein Datenmodell, dass sich mit einer Lager- oder Warenwirtschaft befaßt hat, gesehen, bei dem nicht mindestens ein Produkt von mehreren Lieferanten geliefert wurde. Oft ist es gerade im kaufmännischen Bereich so, daß vor einer Bestellung eine Preisermittlung stattfindet und dann erst bei dem günstigsten Anbieter bestellt wird. Habe ich dann nur eine 1:n-Verknüpfung bleibt mir wohl nichts anderes übrig, als den Artikel mehrfach anzulegen. Plane ich das aber von vorne herein in meinem Datenmodell ein, bereitet mir die "Erweiterung" keine Kopfschmerzen mehr.

Grüße
Mikhal
Michael Kraemer
Computer erleichtern die Arbeit...
...und die Erde ist eine Scheibe!
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#17

Re: Zwei Tabellen mit einander Verknüpfen

  Alt 3. Feb 2005, 15:45
Wie gesagt, das ist nur für mich zum Lernen gedacht. Und da gehe ich erstmal vom einfachsten Fall für zwei Tabellen aus.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Benutzerbild von mikhal
mikhal

Registriert seit: 11. Sep 2003
Ort: Linz am Rhein
796 Beiträge
 
Delphi 11 Alexandria
 
#18

Re: Zwei Tabellen mit einander Verknüpfen

  Alt 3. Feb 2005, 15:46
Fremdschlüssel = Foreign Key

Auf einem SQL-Server kannst du Foreign Keys als Constraints definieren. Dabei kannst du zusätzlich Regeln festlegen, was geschehen soll, wenn sich a) der Datenstz, auf den der Foreign Key verweist geändert wird oder b) wenn der Datensatz, auf den der Foreign Key verweist gelöscht wird.

Ich kenne jetzt MySQL nicht, deshalb kann ich dir nicht sagen, ob und wie du diese Constraints definieren kannst.

Grüße
Mikhal
Michael Kraemer
Computer erleichtern die Arbeit...
...und die Erde ist eine Scheibe!
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#19

Re: Zwei Tabellen mit einander Verknüpfen

  Alt 3. Feb 2005, 15:49
Was sind den jetzt Contrains?
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Tyrael Y.

Registriert seit: 28. Jul 2003
Ort: Stuttgart
1.093 Beiträge
 
Delphi 2007 Professional
 
#20

Re: Zwei Tabellen mit einander Verknüpfen

  Alt 3. Feb 2005, 15:49
@Zottel

Das ist eine n:n -Beziehung da...

Jeder Lieferant ein oder mehrere Produkte haben kann sprich 1:n

und jedes Produkt kann von einem oder mehreren Lieferanten kommen daher auch 1:n

daraus ergibt sich eine n:n -Beziehung zwischen den Tabellen

daher ist eine dritte Tabelle ratsam die folgende Struktur ermöglicht


Lieferant <-> Lieferant/Produkt <-> Produkt
___1:n________n:1___1:n___________n:1______


PS: mehr Infos darüber überall im I-Net unter dem Stichwort
"Normalisierung" erhältlich


mfg
Levent Yildirim
Erzeugung von Icons aus Bildern:IconLev
  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 19:40 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