在mysql中创建触发器以生成UUID

Thu*_*der 6 mysql

如何在插入MySQL之前尝试创建触发器时抛出错误,以便为每个输入生成新的UUID.

CREATE TRIGGER insert_guid 
BEFORE INSERT ON guid_tool (FOR EACH  ROW 
BEGIN 
  SET NEW.guid_key = UUID()); 
END;
Run Code Online (Sandbox Code Playgroud)

这是我的桌子

create table guid_tool (
    ID INT NOT NULL AUTO_INCREMENT, 
    guid_key CHAR(40) NOT NULL, 
    PRIMARY KEY(ID)
) CHARSET=LATIN1;
Run Code Online (Sandbox Code Playgroud)

我一定做错了什么.

mad*_*vid 9

正如@mabi在评论中所提到的 - 括号中存在语法错误.以下修改后的代码适用于我:

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

测试出来:

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)
Run Code Online (Sandbox Code Playgroud)


Pau*_*gas 6

您可以在一个语句中定义该触发器,即:

在为每一行设置的 guid_tool 上插入之前创建触发器 insert_guid NEW.guid_key = UUID();