![]() |
Datenbank: MySQL • Zugriff über: phpMyAdmin, PHP
MySQL: Unique für eine Kombination...
Hi,
ist folgendes Möglich. Ich habe eine Tabelle mit 2 Spalten, Kursname und Lehrer-ID. Nun gibt es Kurse, die gleich heißen, aber andere Lehrer haben, z.B. Biologie - Lehrer-ID 1 und Biologie - Lehrer-ID 2 Gibt es nun eine Möglichkeit, das ganze so zu verwenden, dass beim Eintragen zwar einzelne Werte doppelt vorkommen können, nicht aber eine Kombination, z.B.
Code:
soll gehen.
Biologie | 1
Biologie | 2 Englisch | 2
Code:
soll nicht gehen.
Biologie | 1
Biologie | 1 Englisch | 2 [edit=sakura] [Klammern entfernt] Mfg, sakura[/edit] |
Re: MySQL: Unique für eine Kombination...
Hallo,
bastel dir doch einfach eine SP die das überprüft. Dann würde ich mir 3 Tabellen anlegen. Lehrer, Fach und eine wo du Detail-Tabelle wo die Lehrer und Fächer über die ID eingetragen werden. Bei Speichern kannst Du das überprüfen und ggf. eine Meldung auswerfen oder eben nichts unternehmen.
SQL-Code:
Wenn nun keine Kompination vorhanden ist kann gespeichert werden und wenn eben diese Kompination schon da ist wird ne Meldung ausgegeben.
Select Count(*) From Details WHERE Fach = :iFach_ID AND Lehrer = :iLehrer_ID
Into :oCount IF oCount = 0 Then Dann speichern |
Re: MySQL: Unique für eine Kombination...
Hallo Markus,
mach dir eine Tabelle fuer die Faecher, und eine fuer die Lehrer, sowie eine dritte Tabelle, welche nur die Faecher und Lehrer verbindet. In dieser Kreuztabelle definierst du einfach FachID und LehrerID gemeinsam als Primary Key. Somit wirds beim Einfuegen krachen falls die Kombination aus FachID und LehrerID bereits eingetragen ist. Greetz alcaeus |
Re: MySQL: Unique für eine Kombination...
Hallo,
vielen Dank, das werd ich versuchen. |
Re: MySQL: Unique für eine Kombination...
Du kannst auch einen Unique Key auf mehrere Felder legen...
SQL-Code:
Ob das aber jetzt datenbanktechnisch die beste Lösung ist, hab ich hierbei nicht berücksichtigt
alter table Test
add UNIQUE KEY `unqFachLehrer` (`fach`,`lehrer`) |
Alle Zeitangaben in WEZ +1. Es ist jetzt 14:09 Uhr. |
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