我在mysql和laravel中创建了数据库触发器它工作正常,但是当我移动到postgresql时,我收到错误:
sqlSTATE[42601]: Syntax error: 7 ERROR: Syntax error at or near "BEGIN"
(我是新用的postgresql btw)
这是我在迁移中所做的代码:
DB::unprepared('CREATE TRIGGER histories_insert AFTER INSERT ON packets FOR EACH ROW
BEGIN
IF new.status = "pending" THEN
insert into `histories` (`packet_id`, `message`, `created_at`, `updated_at`) VALUES (new.id, "Barang berhasil di buat", Now(), Now());
END IF;
END');
我真的很困惑.希望可以有人帮帮我 :)
解决方法:
MysqL和postgre中的语法和结构是不同的,在Postgres中我们必须首先编写触发器函数(procedure)然后我们在触发器的主体中调用它
所以之后
FORE EACH ROW
应该有一个
when event __type_of_event__
execute procedure __procedure_name__
看一下有关触发器here的文档
并触发程序here
注意到当事件是可选的,并且过程中的字段名称应该更改为纯文本,或者用双引号括起来(如果它与大写字母混合)
不要担心文档的版本,postgresql触发器在不同版本中是一致的,希望这有帮助!
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。