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

需求如下

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

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

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

乌鸦嘴社区 wyz.xyz 来玩。
《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 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年前 评论

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