Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi MySQL: Unique für eine Kombination... (https://www.delphipraxis.net/40947-mysql-unique-fuer-eine-kombination.html)

Markus 23. Feb 2005 16:34

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:
Biologie | 1
Biologie | 2
Englisch | 2
soll gehen.

Code:
Biologie | 1
Biologie | 1
Englisch | 2
soll nicht gehen.

[edit=sakura] [Klammern entfernt] Mfg, sakura[/edit]

Albi 23. Feb 2005 17:28

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:
Select Count(*) From Details WHERE Fach = :iFach_ID AND Lehrer = :iLehrer_ID
     Into :oCount
     
     IF oCount = 0 Then
       Dann speichern
Wenn nun keine Kompination vorhanden ist kann gespeichert werden und wenn eben diese Kompination schon da ist wird ne Meldung ausgegeben.

alcaeus 23. Feb 2005 18:02

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

Markus 25. Feb 2005 15:28

Re: MySQL: Unique für eine Kombination...
 
Hallo,

vielen Dank, das werd ich versuchen.

Jelly 25. Feb 2005 16:48

Re: MySQL: Unique für eine Kombination...
 
Du kannst auch einen Unique Key auf mehrere Felder legen...

SQL-Code:
alter table Test
add UNIQUE KEY `unqFachLehrer` (`fach`,`lehrer`)
Ob das aber jetzt datenbanktechnisch die beste Lösung ist, hab ich hierbei nicht berücksichtigt


Alle Zeitangaben in WEZ +1. Es ist jetzt 14:59 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