我必须在这些表之间创建关系:
如您所见,我需要关联 4 个表来创建四元关系,假设数据库模型没问题,我怎么能用 eloquent 建立关系?
在模型主题
public function curs_academic(){ // as academic year
return $this->belongsToMany('App\Curs_academic', 'assignatura_alumne_curs_professor', 'id_assignatura', 'id_curs_academic');
}
public function user(){ //as teacher
return $this->belongsToMany('App\User', 'assignatura_alumne_curs_professor', 'id_assignatura', 'id_usuari');
}
学生失踪了,因为我连三元都做不到..
当我保存时,我这样做:
public function update(Request $request, $id)
{
$this->validate($request,[
'nom'=> 'required',
]);
$assignatura = Assignatura::find($id);
$assignatura->nom = $request->input('nom');
$assignatura->save();
$assignatura->estudi()->associate($request->estudis);
$assignatura->curs_academic()->sync($request->curs_academic,false);
$assignatura->user()->sync($request->professors,false);
$assignatura->save();
return redirect('/assignatures')->with('success','Assignatura modificada');
}
pd:数据库模型可以改变,我试图撤消四元关系,但没有它就没有意义(对我来说)。
表单输入:
<div class="form-group col-lg-6">
{!! Form::label('curs_academic', 'Curs academic') !!}
{!! Form::select('curs_academic[]', $cursos_academics, $assignatura->curs_academic()->pluck('curs_academics.id'), ['id' => 'curs_academic','multiple' => 'multiple', 'class' => 'selectpicker', 'data-live-search' => 'true']) !!}
</div>
<div class="form-group col-lg-6">
{!! Form::label('professor', 'Professor') !!}
{!! Form::select('professors[]', $professors, $assignatura->user()->pluck('users.id'), ['id' => 'professors','multiple' => 'multiple', 'class' => 'selectpicker', 'data-live-search' => 'true']) !!}
</div>
目标表:
学科-学生-年级-教师。数学 - 伊万 - 2019 - 大卫。// 数学 - ivan - 2018 - 大卫。