繁体   English   中英

UPDATE TRIGGER 中的“WHERE”条件给出语法错误:mysql 5.7 版

[英]'WHERE' condition in an UPDATE TRIGGER giving syntax error :mysql version 5.7

我正在使用 mysql 数据库(版本 5.7)。

我使用以下 CREATE 命令创建了一个表:

CREATE TABLE `attendance` (
  `id` varchar(11) NOT NULL,
  `hash` char(8) NOT NULL,
  `time_in` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP,
  `time_out` datetime DEFAULT NULL,
  `time_spent` time DEFAULT NULL,
  `purpose` char(10) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

我有一个带有以下查询的触发器:

DELIMITER $$

CREATE TRIGGER test_trigger 
BEFORE UPDATE ON attendance 
FOR EACH ROW 
BEGIN 
SET NEW.time_spent=TIMEDIFF(NEW.time_out,OLD.time_in) WHERE OLD.time_spent IS NULL; 
END$$

DELIMITER ;

但是mysql给出了以下错误:

ERROR 1064 (42000): 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 'WHERE OLD.time_spent IS NULL; END' at line 1

( where 条件确保只有当前天记录得到更新)

我应该如何编写查询?

不能在触发器内使用带有SETWHERE子句。 使用IF代替:

DELIMITER $$

CREATE TRIGGER test_trigger 
BEFORE UPDATE ON attendance 
FOR EACH ROW 
BEGIN
    IF OLD.time_spent IS NULL THEN
        SET NEW.time_spent = TIMEDIFF(NEW.time_out, OLD.time_in);
    END IF;
END$$

DELIMITER ;

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM