Laravel 5关系不起作用?

时间:2015-04-09 12:16:34

标签: laravel relationship laravel-5

在我的应用程序中,我的模型很少:用户和个人资料。用户模型仅适用于公司,我的应用仅适用于公司。当用户注册时,他们只填写他们的姓名,电子邮件地址和密码。我的个人资料模型包含公司名称,地址等列。我的个人资料表单不起作用;不保存到数据库。这是设置:

表单的控制器:

public function update($company_name)
{
  $user = User::whereCompanyName($company_name)->firstOrFail();

      $user->fill(Input::all());

      $user->save();

      flash('You have successfully edited your profile');

      return redirect('/');
}

user.php的:

public function profile()
{
    return $this->hasOne('Profile');
}

Profile.php:

protected $fillable = ['company_name', 'company_logo', 'company_founded'];

public function user()
{
    return $this->belongsTo('App\User', 'user_id','ID');
}

表格:

{!! Form::model($user, array('method' => 'PATCH', 'route' => array('profile.update', $user->company_name), 'files' => true)) !!}
{!! Form::hidden('user_id', Auth::user()->id) !!}

    // more fields

<div class="form-group">
    {!! Form::label('company_name', 'Company Name') !!}
    {!! Form::text('company_name', null, ['class' => 'form-control']) !!}
 </div>

{!! Form::submit('Update Profile', ['class' => 'btn btn-primary']) !!}
{!! Form::close() !!}

我是否设置了正确的关系?什么都没有保存到数据库。

3 个答案:

答案 0 :(得分:1)

您只更新用户模型和用户模型。您还需要在profile关系中设置属性:

$user->update(Input::all());
$user->profile->update(Input::all());

您的控制器操作也可以稍微整理一下,使用route–model binding注入您的User模型实例,并使用服务容器提供Request实例,以便您'我没有使用Input幕墙:

public function update(User $user, Request $request)
{
    $user->update($request->all());
    $user->profile->update($request->all());

    flash('You have successfully updated your profile.');

    return redirect('/');
}

答案 1 :(得分:0)

我想评论,但没有足够的声誉:(前几天我发现这种方法有点问题:

$user->update(Input::all());
$user->profile->update(Input::all());

在这种情况下,相关模型中的 mutators (示例中的配置文件)不会被调用(可能是错误):

public function setLoremIpsumAttribute($attr)
{
    # code
}

控制器中,我尝试了另一种方法,它起作用了:

$user->update($request->all());
$user->profile->fill($request->all()['profile'])->push();

答案 2 :(得分:0)

在Laravel 5中,当你想要用关系链接时,你需要例如(与评论有关的帖子)使用评论中的方法。

Post::find(id)->comment()->where(your where statement)

Laravel的文件:

如果您需要为检索的注释添加更多约束,可以调用comments方法并继续链接条件:

$comments = Post::find(1)->comments()->where('title', '=', 'foo')->first();