updateOrCreate方法有没有办法对日期进行增加操作?

需求如下

1,如果没有数据,就插入数据。
2,如果有数据,就对这个数据的日期(某个日期字段,比如end_at),增加1个月。

我想的是使用updateOrCreate(),但是不知道怎么实现上面的第二个需求。请教各位大神。有办法实现吗?

还是说,遇到这种需求,就只能乖乖的去查询有没有数据,然后根据查询结果进行单独的update或者create?

乌鸦嘴社区 wyz.xyz 来玩。
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
讨论数量: 4

可以用firstOrNew,然后判断是否存在,存在就加一个月,不存在就save创建

2年前 评论
shebaoting (楼主) 2年前

可以在观察者 updating 方法中进行判断

2年前 评论
return tap(abc::query()->firstOrNew($where), function ($instance) use ($data) {
            if (!$instance->isDirty()) {
                $instance->fill($data)->save();
            }
        });
2年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!