MySQL&插入前触发

时间:2013-02-15 10:28:52

标签: mysql triggers

我需要在我的数据库中创建一个触发器。 触发器必须能够在插入之前分析事件。如果数据库中已存在的最后一个事件具有相同的状态,则触发器必须取消插入并更新最后一个事件。

我尝试创建一个,但由于mysql错误,我无法将其添加到我的数据库中:

#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 '' at line 5 

这里是触发器:

CREATE TRIGGER events_before_insert
BEFORE INSERT ON monitoringV2.events
FOR EACH ROW
BEGIN
DECLARE id_last_event;
DECLARE status_last_event;

SELECT id INTO id_last_event, status INTO status_last_event FROM events WHERE module_id=NEW.module_id ORDER BY serverDate DESC LIMIT 1;

IF NEW.status = status_last_event THEN
UPDATE events SET serverDate=NOW() WHERE id=id_last_event;
signal sqlstate '00000' set message_text = "Update instead of insert";
END IF;
END;

以下是信息服务器:

PHP 5.4.6 VC9
Apache 2.4.2 VC9
MySQL 5.5.27
PhpMyAdmin 3.5.2.2

感谢您的帮助

此致

Dorine M。

3 个答案:

答案 0 :(得分:0)

你必须在创建像这样的触发器之前更改DELIMITER

DELIMITER $$
CREATE TRIGGER... 
...
END;
$$
DELIMITER ;

答案 1 :(得分:0)

您可能不需要为此实现触发器。您描述的操作正式称为UPSERT,即更新或插入。

This是如何在MySQL中完成的,你也可以查看REPLACE

Here是另一个涉及此问题的问题。

答案 2 :(得分:0)

您需要分隔您的create语句:

delimiter //
CREATE...
...
END;
//
DELIMITER ;

您可能需要为声明的每个变量定义一个类型,例如

DECLARE x INT;