PHP-Einfach.de
  • PHP Tutorial
  • MySQL Tutorial
  • Für Fortgeschrittene
  • Webhosting
  • Forum

MySQL Fremdschlüssel

1. Dezember 2019
  1. Home
  2. »
  3. MySQL Tutorial
  4. »
  5. MySQL Fremdschlüssel

Bei Datenbank wird zwischen Primärschlüsseln und Fremdschlüsseln unterschieden. Ein Primärschlüssel identifiziert jeden Datensatz einer Tabelle eindeutig. Dies ist zumeist eine Id-Spalte eurer Tabelle und beim Erstellen der Tabelle wurde bereits in phpMyAdmin spezifiziert, dass diese Spalte als Primärschlüssel dient.

Fremdschlüssel sind dagegen Spalten die auf Primärschlüssel anderer Tabellen verweisen.

1
2
3
4
5
6
7
Tabelle 'users'                Tabelle 'beitraege'
+----+---------+----------+   +----+--------+---------+
| id | vorname | nachname |   | id | userid | text    |
+----+---------+----------+   +----+--------+---------+
|  1 | Max     | Meier    |   |  1 |      1 | Super!  |
|  2 | Lisa    | Müller   |   |  2 |      2 | Klasse! |
+----+---------+----------+   +----+--------+---------+

Im obigen Beispiel wären die Spalten id jeweils der Primärschlüssel der Tabellen user und beitraege. Die Spalte userid ist in diesem Beispiel ein Fremdschlüssel der auf die Tabelle users verweist.

Soweit nichts besonders. Ein Problem entsteht nun, falls ihr in der Tabelle users den ersten Eintrag mit der Id 1 löscht. In der Tabelle beitraege habt ihr dann eine tote Verknüpfung. Der erste Beitrag verweist auf den User mit der Id 1, dieser existiert aber nicht mehr. Somit habt ihr Müll in eurer Datenbank, der wiederum später unangenehme Auswirkungen auf eurer Anwendung haben kann.

Fremdschlüssel in MySQL definieren

In MySQL lassen sich, sofern die Speicherengine InnoDB genutzt wird, Fremdschlüsselbeziehungen definieren und überprüfen. Durch die Überprüfung könnt ihr sicherstellen, dass keine toten Verknüpfungen mehr existieren und ihr dadurch Müll in eurer Tabelle besitzt.

In der Übersicht eurer Datenbanktabellen listet euch phpMyAdmin in der Spalte Typ die genutzt Speicherengine auf. Die Speicherengine ist das interne Format, indem MySQL die Daten auf der Festplatte abspeichert. Früher wurde zumeist MyISAM genutzt, seit MySQL 5.5.5 ist allerdings InnoDB die Standard-Speicherengine von MySQL. Persönlich empfehle ich stets InnoDB als Speicherengine zu verwenden, da es mehr Funktionalität als MyISAM anbietet. Die Speicherengine könnt ihr beim Erstellen einer Tabelle in phpMyAdmin auswählen.

Um nun eine Fremdschlüsselbeziehung in phpMyAdmin zu erstellen, müsst ihr folgende Schritte ausführen:

1) Erstellt einen Index für die Fremdschlüsselspalte

Damit ihr einen Fremdschlüssel erstellen könnt, muss diese Spalte als UNIQUE oder als INDEX definiert sein.  Wie dies geht erfahrt ihr im Artikel Optimierung von MySQL: Verwendung des Index.

2) Erstellt eine Fremdschlüsselbedingung

Wechselt dazu in phpMyAdmin in den Struktur-Tab eurer Tabelle in der ihr einen Fremdschüssel erstellen wollt. Im obigen Beispiel also in den Struktur-Tab der beitraege-Tabelle. Dort sollte ein Link Beziehungsansicht oder Beziehungsübersicht zu finden sein. Danach solltet ihr die folgende (oder eine ähnliche) Ansicht erhalten.

phpMyAdmin FremdschlüsselDort könnt ihr auswählen, für welchen Spalte der beitraege-Tabelle ihr einen Fremdschlüssel erstellt wollt. In unserem Beispiel für die Spalte userid. Dieser Fremdschlüssel zeigt dabei auf die Spalte id der Tabelle users (die sich in der Datenbank test befindet). Das Feld für den Constraint-Name könnt ihr leer lassen, phpMyAdmin wählt selbst einen passenden Namen.

Ebenfalls könnt ihr das Verhalten definieren dass bei einem DELETE passieren soll und dass bei einem UPDATE passieren soll.

Angenommen der User wird aus der Users-Tabelle gelöscht. Dann könnt ihr in der Beiträge-Tabelle definieren, was dort mit den Beiträgen des Benutzers passieren soll:

  • Bei RESTRICT wird das Löschen des Nutzers verhindert sofern dieser noch Beiträge hat.
  • Bei CASCADE werden alle Beiträge des Nutzers gelöscht.
  • Bei SET NULL wird die userid für alle Beiträge des Nutzers auf Null gesetzt.
  • NO ACTION verhält sich identisch zu RESTRICT. NO ACTION kommt aus dem SQL-Standard, wird aber von MySQL identisch zu RESTRICT behandelt.

Bei ON UPDATE verhält es sich ähnlich. Angenommen die Id des Benutzers verändert sich, so wird bei RESTRICT dieses Update verhindert. Bei CASCADE wird die aktualisierte Nutzer-Id übernommen, sprich, alle Beiträge erhalten damit automatisch die korrekte Id.

Persönlich setze ich den Wert meistens auf RESTRICT oder auf CASCADE. Allerdings solltet ihr bei CASCADE vorsichtig sein. Löscht ihr einen Nutzer versehentlich, dann sind auch sämtliche seiner Beiträge gelöscht. Diese Daten wiederherzustellen kann unangenehm sein.

Autor: Nils Reimers
Zurück: MySQL Normalformen
Weiter: Übersicht SQL-Befehle

MySQL Tutorial

  • MySQL installieren und starten
  • phpMyAdmin
  • Verbindung aufbauen
  • Simple Datenabfrage
  • Komplexere Datenabfrage
  • Prepared Statements
  • Daten einfügen
  • Daten aktualisieren
  • Daten löschen
  • Gefundene Einträge zählen
  • DATE-Datenbankspalten
  • Datum- und Zeitfunktionen
  • MySQL Fehlermeldungen
  • Datenbankverbindung schließen
  • JOIN
  • Indizes
  • Normalformen
  • Fremdschlüssel
  • Übersicht SQL-Befehle
  • Crashkurs MySQL
  • Crashkurs MySQLi
  • Crashkurs PDO
Mit freundlicher Unterstützung von:
  • Punkt191 Werbeagentur

Hoster – Geringste Ausfallzeit

  1. netcup Ø 0 Min.
  2. webgo Ø 0 Min.
  3. Linevast Ø 3 Min.
  4. All-Inkl.com Ø 3 Min.
  5. checkdomain Ø 4 Min.
  6. dogado Ø 6 Min.
  7. Strato Ø 8 Min.
  8. manitu Ø 10 Min.
  9. 1&1 Ø 10 Min.
  10. DomainFactory Ø 14 Min.
» Mehr erfahren

Impressum | Datenschutz | Auf PHP-Einfach.de werben

© PHP-Einfach.de 2003 - 2025

Cookie-Zustimmung verwalten
Um dir ein optimales Erlebnis zu bieten, verwenden wir Technologien wie Cookies, um Geräteinformationen zu speichern und/oder darauf zuzugreifen. Wenn du diesen Technologien zustimmst, können wir Daten wie das Surfverhalten oder eindeutige IDs auf dieser Website verarbeiten. Wenn du deine Zustimmung nicht erteilst oder zurückziehst, können bestimmte Merkmale und Funktionen beeinträchtigt werden.
Funktional Immer aktiv
Die technische Speicherung oder der Zugang ist unbedingt erforderlich für den rechtmäßigen Zweck, die Nutzung eines bestimmten Dienstes zu ermöglichen, der vom Teilnehmer oder Nutzer ausdrücklich gewünscht wird, oder für den alleinigen Zweck, die Übertragung einer Nachricht über ein elektronisches Kommunikationsnetz durchzuführen.
Vorlieben
Die technische Speicherung oder der Zugriff ist für den rechtmäßigen Zweck der Speicherung von Präferenzen erforderlich, die nicht vom Abonnenten oder Benutzer angefordert wurden.
Statistiken
Die technische Speicherung oder der Zugriff, der ausschließlich zu statistischen Zwecken erfolgt. Die technische Speicherung oder der Zugriff, der ausschließlich zu anonymen statistischen Zwecken verwendet wird. Ohne eine Vorladung, die freiwillige Zustimmung deines Internetdienstanbieters oder zusätzliche Aufzeichnungen von Dritten können die zu diesem Zweck gespeicherten oder abgerufenen Informationen allein in der Regel nicht dazu verwendet werden, dich zu identifizieren.
Marketing
Die technische Speicherung oder der Zugriff ist erforderlich, um Nutzerprofile zu erstellen, um Werbung zu versenden oder um den Nutzer auf einer Website oder über mehrere Websites hinweg zu ähnlichen Marketingzwecken zu verfolgen.
Optionen verwalten Dienste verwalten Anbieter verwalten Lese mehr über diese Zwecke
Einstellungen ansehen
{title} {title} {title}