Laravel里firstOrCreate、firstOrNew、updateOrCreate 方法使用

在日常开发的过程中,经常会遇到判断一条记录是否存在、存在更新、不存在新建记录这种场景,在 Laravel 中提供了方法支持,那么下面就看下具体的方法; 使用时请注意版本,下面介绍的函数 firstOrCreate 和 firstOrNew 跟版本有很大的关系

一、firstOrCreate

firstOrCreate方法将会使用指定的字段=>值对,来尝试寻找数据库中的记录。如果在数据库中找不到,5.5以下版本会使用属性添加一条记录,5.5及以上版本则将使用第一个参数中的属性以及可选的第二个参数中的属性插入记录

用法

User::firstOrCreate(['name' => 'Lisi']);
User::firstOrCreate(['name' => 'Lisi'], ['age' => 20]);  // 5.5及以上版本支持

查看源码:

# 小于 5.5 版本,只有一个参数public function firstOrCreate(array $attributes){    if (! is_null($instance = $this->where($attributes)->first())) {        return $instance;
    }    $instance = $this->model->newInstance($attributes);    $instance->save();    return $instance;
}# 5.5 版本public function firstOrCreate(array $attributes, array $values = []){    // 判断是否存在,如果存在,返回实例
    if (! is_null($instance = $this->where($attributes)->first())) {        return $instance;
    }    // 不存在创建,此代码简化就是 $this->newModelInstance($attributes + $values)->save();
    return tap($this->newModelInstance($attributes + $values), function ($instance) {        $instance->save();
    });
}

二、firstOrNew

会尝试使用指定的属性数据库中寻找符合的纪录。如果未被找到,将会返回一个新的模型实例。请注意 firstOrnew返回的模型还尚未保存到数据库。你需要通过手动调用save方法来保存它

用法

User::firstOrNew(['name' => 'Lisi']);
User::firstOrNew(['name' => 'Lisi'], ['age' => 20]); // 5.5及以上版本支持

查看源码:

# 小于 5.5 版本,只有一个参数public function firstOrNew(array $attributes){    if (! is_null($instance = $this->where($attributes)->first())) {        return $instance;
    }    return $this->model->newInstance($attributes);
}# 5.5 版本public function firstOrNew(array $attributes, array $values = []){    if (! is_null($instance = $this->where($attributes)->first())) {        return $instance;
    }    return $this->newModelInstance($attributes + $values);
}

查看源码就更清楚firstOrCreate比firstOrNew多了save方法,两个方法都很实用,根据场景使用它。

三、updateOrCreate

更新数据,如果不存在则创建,这个函数就充分利用到了方法 firstOrNew,此函数版本之间变化不大

用法

User::updateOrCreate(['name' => 'Lisi'], ['age' => 20]);

查看源码:

# 5.5 版本public function updateOrCreate(array $attributes, array $values = []){    return tap($this->firstOrNew($attributes), function ($instance) use ($values) {        $instance->fill($values)->save();
    });
}

总结

  • firstOrCreate:判断之后直接入库

  • firstOrNew:判断之后还要做其他业务流程,之后再入库

  • updateOrCreate:更新数据,如果不存在则创建


相关文章

[laravel] laravel的数据库配置 找到程序目录结构下.env文件 配置基本的数据库连接信息 DB_HOST=127.0....
[Laravel] Laravel的基本HTTP路由 使用Laravel的基本路由,实现get请求响应,找到文件app/Http/routes....
如果说laravel框架的核心是什么,那么无疑是服务容器。理解服务容器的概念,对于我们使用laravel太重要...
网上有很多解析laravel中间件的实现原理,但是不知道有没有读者在读的时候不明白,作者是怎么想到要用a...
laraveli添加一个或多个用户表,以admin为例。 部分文件内容可能需要根据实际情况修改 创建一个Admin模...
TL;DR: 本文介绍 Laravel 的 FastExcel 组件,文中会对 PHP generators 速览,并给出如何在节约内存的同...