繁体   English   中英

向数据透视表Laravel添加值

[英]Add values to pivot table laravel

当我想保存对票的反应时,我有三个表(在laravel中):

-Tickets
-Reaction
-Reaction_Tickets (pivot table)

当我想保存反应时,请按照以下步骤操作:

public function addReaction(Request $request, $slug)
    {
        $ticket = Ticket::whereSlug($slug)->firstOrFail();
        $reaction = new reactions(array(
            'user_id' => Auth::user()->id,
            'content' => $request->get('content')
            ));

        return redirect('/ticket/'.$slug)->with('Reactie is toegevoegd.');
    }

但是,现在当然不会将其添加到数据透视表中。 而且我无法添加它,因为我没有它的模型。 什么是正确的方法?

编辑:

-Tickets

public function reactions()
{
    return $this->belongsToMany('App\reactions');
}

-Reactions

public function tickets()
{
    return $this->hasOne('App\tickets');
}

从Laravel文档中,您需要保存“ Reaction并将其附加到故障Ticket

$reaction = new reactions(array(
    'user_id' => Auth::user()->id,
    'content' => $request->get('content')
));
$reaction->save(); // Now has an ID
$tickets->reactions()->attach($reaction->id);

Ticket模型中,需要定义关系:

class Ticket extends Model {
    protected $table = "tickets";

    public function reactions(){
        return $this->belongsToMany("App\Reaction"); 
    }
}

并且您应该在Reaction定义反函数:

class Reaction extends Model {
    protected $table = "reactions";

    public function tickets(){
        return $this->belongsToMany("App\Ticket"); 
    }
}

如果您的模型是这样设置的,那么通过数据透视表将新的Reaction到现有Ticket上就不会有任何问题。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM