当前位置:Gxlcms > PHP教程 > 关于laravel的firstOrCreate,数据不存在则创建

关于laravel的firstOrCreate,数据不存在则创建

时间:2021-07-01 10:21:17 帮助过:3人阅读

文档里
// 以属性找用户,若没有则新增并取得新的实例
$user = User::firstOrCreate(['name' => 'John']);如果不存在只能插入name字段
如果是判断name=john的不存在就插入['name' => 'John','age'=>20]呢怎么处理?

回复内容:

文档里
// 以属性找用户,若没有则新增并取得新的实例
$user = User::firstOrCreate(['name' => 'John']);如果不存在只能插入name字段
如果是判断name=john的不存在就插入['name' => 'John','age'=>20]呢怎么处理?

如果你是所有人不存在都插入age=20,而不论是john、Lena,也或者是其他的什么人,那么采用属性修改器

class User extends Model {

    public function setAgeAttribute($value)
    {
        $this->attributes['age'] = 20;
    }

}

如果是每个人都不同的话,可以用updateOrCreate,即

$user = User::updateOrCreate(['name' => 'John'], ['name' => 'John','age'=>20]);

 $users = User::where('name',john)->first();
                if(!$users) $users = new Users;
                $users->age=20;
               $resQuery= users->save();

楼上的经本人测试,不管是什么情况都是更新,并达不到新建的目的。然后我研究了半天重新写的,亲测有效,希望后面的人看到了能够少走弯路

人气教程排行