无法在 phpmyadmin 的 mysql 中创建触发器

Cannot create trigger in mysql at phpmyadmin

在 phpmyadmin 中将一行插入数据库后,我试图通过合并字段来创建 ID。我在以下触发语句的第 3 行收到错误:

DROP TRIGGER IF EXISTS `scanID2`;
CREATE DEFINER=`root`@`localhost` 
TRIGGER `scanID2` 
AFTER INSERT ON db_name.`scan_data` 
FOR EACH ROW 
BEGIN 
UPDATE db_name.scan_data 
SET @data1 = concat(RIGHT(scanContent,2), RIGHT(operatorID,2), RIGHT(deviceID,2), RIGHT (scanDate, '-', ''), REPLACE (scanTime, ':', ''));
INSERT INTO db_name.scan_data(scanID) VALUES (@data1);
END
//

错误是:

#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'CREATE DEFINER=`root`@`localhost`
TRIGGER `scanID2`
AFTER INSERT ON db_name' at line 2 

好的,所以我想出了如何执行查询。触发器已经创建,但我认为它没有完成它应该做的事情。记录不会更新。这是新代码:

BEGIN 
SET @data1 = concat(RIGHT(scanContent,2), RIGHT(operatorID,2), RIGHT(deviceID,2), REPLACE (scanDate, '-', ''), REPLACE (scanTime, ':', ''));
INSERT INTO vacseen1_connect.scan_data(scanID) VALUES (@data1);
END

有几件事需要考虑:

  1. 使用 BEFORE 事件作为触发器而不是 AFTER。这样,您可以在插入行的同时设置 scanID 的值。
  2. 使用 NEW 关键字访问正在插入的行的字段。
  3. 因为它是一个语句触发器,现在您不需要更改分隔符并使用 BEGIN ... END 块。
  4. 您很可能打算对 scanDate 使用 REPLACE

尝试

CREATE TRIGGER scanID2 
BEFORE INSERT ON scan_data 
FOR EACH ROW 
SET NEW.scanID = CONCAT(
    RIGHT(NEW.scanContent, 2), 
    RIGHT(NEW.operatorID, 2), 
    RIGHT(NEW.deviceID, 2), 
    REPLACE(NEW.scanDate, '-', ''), 
    REPLACE (NEW.scanTime, ':', '')
);

这是一个SQLFiddle演示