0

我正在尝试通过将它们添加到从 sqldb.map 调用的 sql 文件中来创建一些数据库触发器创建数据库后。

但是,要创建触发器,我需要使用 delimiter 命令将分隔符更改为分号以外的内容。这失败了,结果触发器创建失败,标准都是you have a syntax error message.. 我可以通过这种方式运行一个简单的 sql 语句,但它不喜欢分隔符。

有什么想法吗?

delimiter //

CREATE TRIGGER `SHOW_ADD_NEWS_ITEM` 
AFTER INSERT ON `show`
FOR EACH ROW 
    BEGIN
        declare username varchar(255);
        IF NEW.privacy_key IS NOT NULL AND NEW.privacy_key <> 'PRIVATE' and (NOT EXISTS (select id from feed_friend_activity 
                where location_identifier = NEW.uuid and user_id = NEW.user_id and event_type = 'published show')) THEN
            select concat(user.first_name,user.last_name) into username from user where user.id = NEW.user_id;
            insert into feed_friend_activity 
                (location_identifier,user_id,event_type,user_name,item_name,created_on) 
                values (NEW.uuid,NEW.user_id,'published show',username,NEW.name,NEW.created_on);
        END IF;
    END
//
4

1 回答 1

1

Propel 1.6.7 现在支持DELIMITER. 有关更多信息,请参阅此拉取请求。如果您的 SQL 是有效的,那么它将在 1.6.7 或更高版本上正常工作。

于 2012-08-16T07:32:40.687 回答