| |
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 |
|
|
sevISDN 1.0
Überwachung aller eingehender Anrufe!
Die DLL erkennt alle über die CAPI-Schnittstelle eingehenden Anrufe und teilt Ihnen sogar mit, aus welchem Ortsbereich der Anruf stammt. Weitere Highlights: Online-Rufident, Erkennung der Anrufbehandlung u.v.m. Weitere InfosTipp des Monats sevZIP40 Pro DLL
Zippen und Unzippen wie die Profis!
Mit nur wenigen Zeilen Code statten Sie Ihre Anwendungen ab sofort mit schnellen Zip- und Unzip-Funktionen aus. Hierbei lassen sich entweder einzelnen Dateien oder auch gesamte Ordner zippen bzw. entpacken. Weitere Infos
|
|
|
Copyright ©2000-2024 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
|
|