Heim >Datenbank >MySQL-Tutorial >Wie kann ein Feld mithilfe von Triggern standardmäßig auf die automatisch generierte ID in MySQL gesetzt werden?

Wie kann ein Feld mithilfe von Triggern standardmäßig auf die automatisch generierte ID in MySQL gesetzt werden?

Mary-Kate Olsen
Mary-Kate OlsenOriginal
2024-11-06 22:14:031021Durchsuche

How to Default a Field to the Auto-Generated ID in MySQL Using Triggers?

MySQL-Trigger, um ein Feld standardmäßig auf den Wert einer automatisch generierten ID zu setzen

In MySQL ist es möglich, Trigger zu erstellen, um bestimmte Aktionen auszuführen Operationen an Tabellendaten vor oder nach Änderungen. Ein häufiger Anwendungsfall besteht darin, ein Feld standardmäßig auf den Wert des automatisch generierten Primärschlüssels (ID) zu setzen, wenn dieser beim Einfügen null bleibt.

Problemstellung:

Um dies zu erreichen, betrachten wir eine Tabelle mit drei Spalten: id (Primärschlüssel), group_id (Ganzzahl) und Wert (varchar). Das Ziel besteht darin, beim Einfügen des Datensatzes das folgende Verhalten zu erzielen:

  • Wenn die Gruppen-ID angegeben ist, ändern Sie sie nicht.
  • Wenn die Gruppen-ID weggelassen wird, setzen Sie sie auf den Wert von neu generierte ID.

Trigger-Implementierung:

Während es wünschenswert wäre, diesen Vorgang innerhalb einer einzelnen Anweisung oder eines einzelnen Triggers auszuführen, verhindern MySQL-Einschränkungen dies. Eine Problemumgehung besteht darin, einen zweistufigen Ansatz zu verwenden:

  1. Erstellen Sie einen BEFORE INSERT-Trigger, um „group_id“ auf „id“ zu setzen, wenn „group_id“ nicht angegeben ist:
CREATE TRIGGER MyTrigger BEFORE INSERT ON MyTable
FOR EACH ROW BEGIN
  SET NEW.group_id = COALESCE(NEW.group_id, NEW.id);
END
  1. Da MySQL keine Änderungen von Spaltenwerten nach INSERT zulässt, muss unmittelbar nach dem Einfügen eine UPDATE-Anweisung ausgeführt werden, um Fälle zu behandeln, in denen group_id weggelassen wurde:
INSERT INTO MyTable (group_id, value) VALUES (NULL, 'a');
UPDATE MyTable SET group_id = COALESCE(group_id, id) WHERE id = LAST_INSERT_ID();

Einschränkungen:

Es ist wichtig zu beachten, dass der BEFORE INSERT-Trigger nicht auf den neu generierten ID-Wert zugreifen kann, da dieser noch nicht zugewiesen wurde. Die Verwendung des AFTER INSERT-Triggers für den Zugriff auf den generierten Wert ist jedoch keine Option, da Spaltenwerte in dieser Phase nicht geändert werden können.

Daher bietet der oben dargestellte zweistufige Ansatz eine Lösung für das gewünschte Verhalten in MySQL .

Das obige ist der detaillierte Inhalt vonWie kann ein Feld mithilfe von Triggern standardmäßig auf die automatisch generierte ID in MySQL gesetzt werden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn