php – Laravel在触发PostgreSQL时在BEGIN附近迁移错误
发布时间:2020-12-14 19:40:43 所属栏目:大数据 来源:网络整理
导读:我在 mysql和laravel中创建了数据库触发器它工作正常,但是当我移动到postgresql时,我收到错误: SQLSTATE[42601]: Syntax error: 7 ERROR: syntax error at or near "BEGIN" (我是新用的postgresql btw) 这是我在迁移中所做的代码: DB::unprepared('CREATE
我在
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触发器在不同版本中是一致的,希望这有帮助! (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |