[英]Laravel 5 | Many to Many Relationship not working
我是laravel5的新手。 我使用“多对多”关系来获取基于给定标签的所有消息。
讯息模式:
function tags(){
return $this->belongsToMany('App\tags')->withTimestamps();
}
标签模型:
public function messages() {
return $this->belongsToMany('App\messages', "messages_tags", "messages_id", "tags_id");
}
我的输入:
$tag = App\tags::where('name','public')->first();
($ tag :)
App\tags {#681
id: "5",
name: "Public",
created_at: "2016-02-10 13:51:36",
updated_at: "2016-02-10 08:21:36",
}
我试图获取带标签的消息。
$tag->messages()->get();
我的输出:
[]
但是我有带有标签“公共”的消息。
我的代码有什么问题?
在您的Message
模型中的tags()
方法中,您还应该提供messages_tags
数据透视表名称(包括“ messages_id”和“ tags_id”),并访问以下messages
:
$tag->messages;
或者您可以使用(快速加载):
$tag = App\tags::with('messages')->where('name','public')->first();
然后使用:
$tag->messages;
请参阅: https : //laravel.com/docs/5.1/eloquent-relationships#many-to-many
您是否有与给定标签相关的消息?
$tag = App\tags::where('name','public')->first();
dd($tag->messages()->get());
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.