Zitat von
Luckie:
Was sind den jetzt Contrains?
Auch wenn "das Thema für dich erledigt ist" noch etwas zu den Fremdschlüsseln. Diese werden von
mySQL seit Version 3.23.44 unterstützt (aber nur bei InnoDB-Tabellen) und müssen dann natürlich auch als solche angegeben werden. Hier mal zwei Tabellen:
SQL-Code:
CREATE TABLE lieferanten
(id INT auto_increment,
name VarChar(100),
PRIMARY KEY (id)
) TYPE=INNODB;
CREATE TABLE artikel
(id INT auto_increment, li_id INT,bezeichnung VarChar(100),
PRIMARY KEY (id),
INDEX li_ind (li_id),
FOREIGN KEY (li_id) REFERENCES lieferanten(id)
ON DELETE CASCADE
) TYPE=INNODB;
Wie man sieht ist die Tabelle
artikel über einen FOREIGN KEY mit einer Referenz auf die ID aus
lieferanten versehen.
Als bedingung ist eingetragen "ON DELETE CASCADE". Was hat dies zu bedeuten fragt sich nun das Luckie *g*
Ganz einfach. Wenn aus der Tabelle lieferanten ein Datensatz gelöscht wird, werden automatisch alle Arikteldatensätze gelöscht bei denen das Feld li_id den gleichen Wert hat wie die ID des gelöschten Lieferanten-DS.
Ausser "Cascade" gibt es noch andere Dinge wie man machen kann:
- RESTRICT -> Ein "Master" Datensatz kann nicht gelöscht werden wenn es noch abhängige DS gibt
- CASCADE -> Siehe oben
- SET NULL -> Das Feld des FOREIGN Keys (li_id) wird auf NULL gesetzt
- NO ACTION -> nix
- SET DEFAULT -> Das Feld wird auf den angegebenen Defaultwert gesetzt.
Stephan B.
"Lasst den Gänsen ihre Füßchen"