欢迎各位兄弟 发布技术文章
这里的技术是共享的
简单来说 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