Laravel 5.2 使用 Associate 更新 BelongsTo 关系
Laravel 5.2 Using Associate to Update a BelongsTo Relationship
我正在使用路由模型绑定来获取用户实例,然后在验证通过时更新它,然后更新关联的属于用户和配置文件之间的关系,但我一直收到错误消息。更新发生在用户身上,但更新配置文件失败。从我从文档中了解到的情况来看,这似乎是正确的。我可以使用 $user->profile
访问配置文件数据,因此 User 和 UserProfile 模型中的关系似乎没问题。
谁能看出这个控制器操作有什么问题:
public function update(Request $request, User $user)
{
$this->validate($request, [
'username' => 'required|max:32|unique:users',
'email' => 'required|email|max:128|unique:users',
'first_name' => 'required',
'last_name' => 'required',
'phone_number' => 'regex:/^([0-9\s\-\+\(\)\.]*)$/',
]);
$user->update($request->all());
$profile = new UserProfile($request->all());
// Also tried:
//$profile = UserProfile::where(['user_id' => $user->id])->first();
$user->profile()->associate($profile);
$user->save();
return response()->json([
'message' => trans('user.updated'),
]);
}
错误
BadMethodCallException in Builder.php line 2161:
Call to undefined method Illuminate\Database\Query\Builder::associate()
用户模型关系
/**
* A user has-one profile.
*
* @return \Illuminate\Database\Eloquent\Relations\HasOne
*/
public function profile()
{
return $this->hasOne('App\UserProfile');
}
UserProfile 模型关系
/**
* A user profile belongs to a user.
*
* @return \Illuminate\Database\Eloquent\Relations\HasOne
*/
public function user()
{
return $this->belongsTo('App\User');
}
解决方案
$user->fill($request->all())->save();
$profile = UserProfile::where('user_id', $user->id)->first();
$profile->fill($request->all());
$user->profile()->save($profile);
您必须首先检索或创建新的 profile
实体并将其放入 $profile
。另外,你在这里有一对一的关系,所以你应该像这样保存你的用户配置文件:
$user->profile()->save($profile);
将您的代码更改为:
public function update(Request $request, User $user)
{
$this->validate($request, [
'username' => 'required|max:32|unique:users',
'email' => 'required|email|max:128|unique:users',
'first_name' => 'required',
'last_name' => 'required',
'phone_number' => 'regex:/^([0-9\s\-\+\(\)\.]*)$/',
]);
$profile = UserProfile::create($request->all());
$user->profile()->associate($profile);
$user->save();
return response()->json([
'message' => trans('user.updated'),
]);
}
我正在使用路由模型绑定来获取用户实例,然后在验证通过时更新它,然后更新关联的属于用户和配置文件之间的关系,但我一直收到错误消息。更新发生在用户身上,但更新配置文件失败。从我从文档中了解到的情况来看,这似乎是正确的。我可以使用 $user->profile
访问配置文件数据,因此 User 和 UserProfile 模型中的关系似乎没问题。
谁能看出这个控制器操作有什么问题:
public function update(Request $request, User $user)
{
$this->validate($request, [
'username' => 'required|max:32|unique:users',
'email' => 'required|email|max:128|unique:users',
'first_name' => 'required',
'last_name' => 'required',
'phone_number' => 'regex:/^([0-9\s\-\+\(\)\.]*)$/',
]);
$user->update($request->all());
$profile = new UserProfile($request->all());
// Also tried:
//$profile = UserProfile::where(['user_id' => $user->id])->first();
$user->profile()->associate($profile);
$user->save();
return response()->json([
'message' => trans('user.updated'),
]);
}
错误
BadMethodCallException in Builder.php line 2161:
Call to undefined method Illuminate\Database\Query\Builder::associate()
用户模型关系
/**
* A user has-one profile.
*
* @return \Illuminate\Database\Eloquent\Relations\HasOne
*/
public function profile()
{
return $this->hasOne('App\UserProfile');
}
UserProfile 模型关系
/**
* A user profile belongs to a user.
*
* @return \Illuminate\Database\Eloquent\Relations\HasOne
*/
public function user()
{
return $this->belongsTo('App\User');
}
解决方案
$user->fill($request->all())->save();
$profile = UserProfile::where('user_id', $user->id)->first();
$profile->fill($request->all());
$user->profile()->save($profile);
您必须首先检索或创建新的 profile
实体并将其放入 $profile
。另外,你在这里有一对一的关系,所以你应该像这样保存你的用户配置文件:
$user->profile()->save($profile);
将您的代码更改为:
public function update(Request $request, User $user)
{
$this->validate($request, [
'username' => 'required|max:32|unique:users',
'email' => 'required|email|max:128|unique:users',
'first_name' => 'required',
'last_name' => 'required',
'phone_number' => 'regex:/^([0-9\s\-\+\(\)\.]*)$/',
]);
$profile = UserProfile::create($request->all());
$user->profile()->associate($profile);
$user->save();
return response()->json([
'message' => trans('user.updated'),
]);
}