AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi MySQL: Unique für eine Kombination...
Thema durchsuchen
Ansicht
Themen-Optionen

MySQL: Unique für eine Kombination...

Ein Thema von Markus · begonnen am 23. Feb 2005 · letzter Beitrag vom 25. Feb 2005
Antwort Antwort
Markus
(Gast)

n/a Beiträge
 
#1

MySQL: Unique für eine Kombination...

  Alt 23. Feb 2005, 16:34
Datenbank: MySQL • Zugriff über: phpMyAdmin, PHP
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]
  Mit Zitat antworten Zitat
Albi

Registriert seit: 4. Mai 2003
Ort: Berlin
458 Beiträge
 
Delphi 7 Professional
 
#2

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

  Alt 23. Feb 2005, 17:28
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.
  Mit Zitat antworten Zitat
Benutzerbild von alcaeus
alcaeus

Registriert seit: 11. Aug 2003
Ort: München
6.537 Beiträge
 
#3

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

  Alt 23. Feb 2005, 18:02
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
Andreas B.
Die Mutter der Dummen ist immer schwanger.
Ein Portal für Informatik-Studenten: www.infler.de
  Mit Zitat antworten Zitat
Markus
(Gast)

n/a Beiträge
 
#4

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

  Alt 25. Feb 2005, 15:28
Hallo,

vielen Dank, das werd ich versuchen.
  Mit Zitat antworten Zitat
Benutzerbild von Jelly
Jelly

Registriert seit: 11. Apr 2003
Ort: Moestroff (Luxemburg)
3.741 Beiträge
 
Delphi 2007 Professional
 
#5

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

  Alt 25. Feb 2005, 16:48
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
  Mit Zitat antworten Zitat
Antwort Antwort


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 11:56 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