作者:哇哈哈 | 来源:互联网 | 2018-05-20 10:59
文档里以属性找用户,若没有则新增并取得新的实例$userUser::firstOrCreate(['name'>'John']);如果不存在只能插入name字段如果是判断namejohn的不存在就插入['name'>'John','age'>20]呢...
文档里
// 以属性找用户,若没有则新增并取得新的实例
$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();
楼上的经本人测试,不管是什么情况都是更新,并达不到新建的目的。然后我研究了半天重新写的,亲测有效,希望后面的人看到了能够少走弯路