php – Laravel在触发PostgreSQL时在BEGIN附近迁移错误

我在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触发器在不同版本中是一致的,希望这有帮助!

相关文章

统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
前言 之前做了微信登录,所以总结一下微信授权登录并获取用户...
FastAdmin是我第一个接触的后台管理系统框架。FastAdmin是一...
之前公司需要一个内部的通讯软件,就叫我做一个。通讯软件嘛...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...