0

我必须在这些表之间创建关系:

数据库模式

如您所见,我需要关联 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 - 大卫。

4

1 回答 1

0

您最终会得到重复的条目,因为您对一张表使用了多个关系。

尝试使用数据透视字段sync()只调用一次。

这是因为 Laravel 不可能知道数据透视表中已经存在的另一条记录,因为它只在特定关系方法中查找键。

一个好的方法是为数据透视表创建一个中间模型,并且只使用BelongsToHasMany关系。然后管理关联变得非常简单。

于 2019-09-17T12:48:44.513 回答