DDL - 不能使用分隔符?



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

但是,要创建触发器,我需要使用分隔符命令将分隔符更改为分号以外的内容。此操作失败,并且结果触发器创建失败,无论是标准、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
//

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

最新更新