欢迎各位兄弟 发布技术文章

这里的技术是共享的

You are here

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

简单来说 firstOrCreate 等价于 先firstOrNew再将其返回的对象save进数据库

文档里
// 以属性找用户,若没有则新增并取得新的实例
$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();


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

来自  http://www.php.cn/php-weizijiaocheng-105887.html

普通分类: