laravel - 如何使用变形术
问题描述
我正在尝试创建一个标记系统,现在我得到了两个表,如下图所示
可标记的
我想根据 `tag_id Journal
. id
但是,日志总是在 taggables 表中创建一条新记录。
这是我的模型关系
标签
class Tag extends Model
{
public function purchases()
{
return $this
->morphedByMany('Purchase', 'taggable');
}
public function taggables()
{
return $this->hasMany('Taggable');
}
}
购买
class Purchase extends Model
{
public function tags()
{
return $this
->morphToMany('Tag', 'taggable');
}
}
杂志
class Journal extends Model
{
public function tags()
{
return $this
->morphToMany('Tag', 'taggable');
}
}
解决方案
如果我理解正确,您正在尝试同时为期刊和购买使用标签。
那么你的表结构应该是这样的:
期刊(id, ...)
购买(id, ...)
标签(id, name)
taggables (id, tag_id, taggable_id, taggable_type)
那么可以标记的模型都应该有一个方法来检索它们的标记:
应用程序/Journal.php
// namespace and use statements
class Journal extends Model
{
public function tags()
{
return $this->morphToMany('App\Tag', 'taggable');
}
}
应用程序/Purchase.php
// namespace and use statements
class Purchase extends Model
{
public function tags()
{
return $this->morphToMany('App\Tag', 'taggable');
}
}
可以同时应用于 Purchase 和 Journal 的标签模型应该有 N 个方法,其中 N 是您通过多态关系连接的不同模型的数量,在本例中 N=2(一种从标签检索购买的方法,以及一种从标签中检索日志的方法)。
应用程序/标签.php
// namespace and use statements
class Tag extends Model
{
public function journals()
{
return $this->morphedByMany('App\Journals', 'taggable');
}
public function purchases()
{
return $this->morphedByMany('App\Purchase', 'taggable');
}
}
设置关系后,您可以检索分配给日记或采购的标签:
$journal = \App\Journal::first();
foreach ($journal->tags as $tag) {
// ...
}
或检索链接到特定标签的所有期刊或购买:
$tag = \App\Tag::first();
// $tag->journals will contain the journals model instances linked to the current tag
// $tag->purchases will contain the purchases model instances linked to the current tag
注意:定义关系使用相关类的 FQDN,例如:'App\Tag'
而不是'Tag'
,否则自动加载器将找不到该类。