Maison > base de données > tutoriel mysql > le corps du texte

Comment mettre à jour automatiquement une colonne avec la valeur ID à l'aide d'un déclencheur MySQL ?

Susan Sarandon
Libérer: 2024-11-07 19:36:02
original
152 Les gens l'ont consulté

How to Automatically Update a Column with the ID Value Using a MySQL Trigger?

Utilisation d'un déclencheur MySQL pour mettre à jour une colonne avec la valeur d'ID

Les déclencheurs MySQL vous permettent d'effectuer automatiquement des actions spécifiques lorsque certains événements se produisent dans une table de base de données. Dans ce cas, nous souhaitons créer un déclencheur qui met à jour la valeur d'une colonne avec la valeur de l'ID de l'enregistrement nouvellement inséré si la colonne est nulle.

L'instruction SQL pour créer un tel déclencheur ressemblerait à ceci :

CREATE TRIGGER [trigger_name] BEFORE INSERT ON [table_name]
FOR EACH ROW BEGIN
  IF NEW.group_id IS NULL THEN
    SET NEW.group_id = NEW.id;
  END IF;
END
Copier après la connexion

Ce déclencheur se déclenchera avant toute opération INSERT sur la table spécifiée. Il vérifie si la colonne group_id est nulle pour le nouvel enregistrement. Si tel est le cas, il définit group_id sur la valeur de la colonne id, qui est la clé primaire générée automatiquement.

Exemple

Considérez le tableau suivant :

CREATE TABLE table_name (
  id INT NOT NULL AUTO_INCREMENT,
  group_id INT NULL,
  value VARCHAR(255) NOT NULL,
  PRIMARY KEY (id)
);
Copier après la connexion

Lors de l'insertion d'un enregistrement avec un group_id spécifié :

INSERT INTO table_name(value, group_id) VALUES ('a', 10);
Copier après la connexion

le déclencheur ne s'exécutera pas et les données seront insérées comme prévu :

id | group_id | value
---+----------+------
 1 |       10 | a
Copier après la connexion

Cependant , lors de l'insertion d'un enregistrement sans spécifier group_id :

INSERT INTO table_name(value) VALUES ('b');
Copier après la connexion

le déclencheur se déclenchera et définira group_id sur l'ID de l'enregistrement nouvellement inséré :

id | group_id | value
---+----------+------
 2 |        2 | b
Copier après la connexion

Remarque : Il est important de s'assurer que le déclencheur ne met à jour la colonne group_id que si elle est nulle pour éviter d'écraser les valeurs existantes.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!