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

需求如下

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

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

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

乌鸦嘴社区 wyz.xyz 来玩。
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《L01 基础入门》
我们将带你从零开发一个项目并部署到线上,本课程教授 Web 开发中专业、实用的技能,如 Git 工作流、Laravel Mix 前端工作流等。
讨论数量: 4

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

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

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

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

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