我正在尝试为类别实现一个可变形表,现在我有以下内容。
// Snippet Table
- id
- title
- body
// Post Table
- id
- title
- body
// Category Table
- id
- name
我希望能够将帖子和片段改为只有一个类别,如下所示:
// Categorizable Table
- category_id
- categorizable_id
- categorizable_type
我是否必须为这个可分类表建立另一个模型?或者有没有其他模型可以设置的方法?
到目前为止我有这个
class Snippet extends Model
{
public function category()
{
return $this->morphOne(Category::class, 'categorizable');
}
}
class Post extends Model
{
public function category()
{
return $this->morphOne(Category::class, 'categorizable');
}
}
class Category extends Model
{
public function categorizable()
{
return $this->morphTo();
}
}
我有4张桌子,snippets
, posts
, categories
, categorizables
,最后一个迁移看起来像这样。
Schema::create('categorizables', function (Blueprint $table) {
$table->increments('id');
$table->unsignedInteger('category_id');
$table->morphs('categorizable');
$table->timestamps();
});
问题是,拯救这段关系的正确方法是什么,我正在修补程序上进行测试attach($category_id)
and sync($category_id)
没有保存关系,他们返回错误BadMethodCallException with message 'Call to undefined method Illuminate\Database\Query\Builder::categorizable()'
,我缺少什么?