| |

ADO.NET / DatenbankenRelationen mit 2 Feldern in mySQL | |  | Autor: Zero-G. | Datum: 28.08.08 16:00 |
| Hallo NG
Ich "ärgere" mich im Moment mit den Relationen (Foreign Keys) im mySQL herum.
Also, anlegen kann ich sie & da gibt es auch kein Problem (mehr)...
So, jetzt habe ich aber folgende Konstellation, die mir sehr schleierhaft erscheint.
Ich habe mehrere Auftragstabellen. - Diese sollen eine Relation zu einer Tabelle haben, die wiederum eine Relation mit den Mitarbeitern hat.
Warum es da um drei Tabellen handelt, ist sehr einfach. - Es können pro Auftrag mehrere Mitarbeiter daran gearbeitet haben.
Ganz vereinfachter Aufbau der Tabellen.
Auftrag1 -> AuftragID, InterneAuftragsNummer
Auftrag2 -> AuftragID, InterneAuftragsNummer
Auftrag_Mitarbeiter -> AuftragID, InterneAuftragsNummer, MitarbeiterID
Mitarbeiter -> MitarbeiterID
So, die InterneAuftrasnummer ist pro Auftrag fix vergeben. Eben aus dem Gedanken heraus, dass natürlich die AuftragsID der Tabellen die gleichen sein könnten.
D.h. meine Relation der Auftrag_Mitarbeiter sieht so aus:
CONSTRAINT `rel_mitarbeiter_auftrag1`
FOREIGN KEY (`auftragid`, `interneauftragsnummer`)
REFERENCES `auftrag1`(`AuftragID`, `interneauftragsnummer`)
ON DELETE CASCADE
ON UPDATE NO ACTION,
CONSTRAINT `rel_mitarbeiter_auftrag2`
FOREIGN KEY (`auftragid`, `interneauftragsnummer`)
REFERENCES `auftrag2`(`AuftragID`, `interneauftragsnummer`)
ON DELETE CASCADE
ON UPDATE NO ACTION So, das Problem ist jetzt, dass sobald ich einen Datensatz einfügen möchte, bekomme ich folgende Fehlermeldung:
Zitat: |  |
SQL Error: Cannot add or update a child row: a foreign key constraint fails (`db/auftrag_mitarbeiter`, CONSTRAINT `rel_mitarbeiter_auftrag2` FOREIGN KEY (`auftragid`, `interneauftragsnummer`) REFERENCES `auftrag2` (`AuftragID`, `interneauftragsnummer`) O)
|  |
Ich dachte, durch die fixe vergabe der internen Auftragsnummer wird dann dort auch unterschieden!?
Kann mir da jemand einen Tipp geben?
DANKE |  |
 | Sie sind nicht angemeldet! Um auf diesen Beitrag zu antworten oder neue Beiträge schreiben zu können, müssen Sie sich zunächst anmelden.
Einloggen | Neu registrieren |
  |
|
Neu! sevCommand 4.0 
Professionelle Schaltflächen im modernen Design!
Mit nur wenigen Mausklicks statten auch Sie Ihre Anwendungen ab sofort mit grafischen Schaltflächen im modernen Look & Feel aus (WinXP, Office, Vista oder auch Windows 8), inkl. große Symbolbibliothek. Weitere InfosTipp des Monats Oktober 2025 Matthias KozlowskiUmlaute konvertierenErsetzt die Umlaute in einer Zeichenkette durch die entsprechenden Doppelbuchstaben (aus ä wird ae, usw.) TOP Entwickler-Paket 
TOP-Preis!!
Mit der Developer CD erhalten Sie insgesamt 24 Entwickler- komponenten und Windows-DLLs. Die Einzelkomponenten haben einen Gesamtwert von 1866.50 EUR...
Jetzt nur 979,00 EURWeitere Infos
|
|
|
Copyright ©2000-2025 vb@rchiv Dieter Otter Alle Rechte vorbehalten.
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein.
Diese Seiten wurden optimiert für eine Bildschirmauflösung von mind. 1280x1024 Pixel
|
|