Mysql
 sql >> Base de données >  >> RDS >> Mysql

Création d'un déclencheur dans mysql pour la génération UUID

Comme mentionné par @mabi dans les commentaires - vous avez une erreur de syntaxe avec les crochets. Le code modifié suivant fonctionne pour moi :

DELIMITER #
CREATE TRIGGER insert_guid 
BEFORE INSERT ON guid_tool
FOR EACH  ROW 
BEGIN 
    SET NEW.guid_key = UUID(); 
END;
#
DELIMITER ;

En test :

mysql> INSERT INTO guid_tool (ID) VALUES (1);
Query OK, 1 row affected, 1 warning (0.04 sec)

mysql> SELECT * FROM guid_tool;
+----+--------------------------------------+
| ID | guid_key                             |
+----+--------------------------------------+
|  1 | a0467ebf-5c4f-11e3-903a-6cccbb4423e3 |
+----+--------------------------------------+
1 row in set (0.00 sec)