同一个 model 中有多个字段 morphone 到另一外模型怎么处理?

问题如标题。

具体场景如下:
表movie中,有thumbnail和video两个morphone,都关联到Media这个类。
Movie类中:

    public function thumbnail()
    {
        return $this->morphOne(Media::class, 'media');
    }
    public function video()
    {
        return $this->morphOne(Media::class, 'media');
    }

Media类中

 public function media()
    {
        return $this->morphTo();
    }

此时,直接取的话,发现thumbnail和video都是取到了同一个media对象。各位有办法处理这种情况吗?

《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 1

搞定。
1、在morphMap中,新建关系

'movie.thumb' => Media::class,
'movie.video' => Media::class,

2、在Movie模型中,定义关系

    public function thumbnail()
    {
        //最后一个参数作为自定义morphClass使用
        return $this->multiMorphOne(Media::class, 'media', 'media_type', 'media_id', 'id', 'movie.thumb');
    }

3、自定义了一个新关系类,继承自Illuminate\Database\Eloquent\Relations\HasOneOrMany
其中构造函数如下:

//最后一个参数$morphClass就是自定义的关系类型
    public function __construct(Builder $query, Model $parent, $type, $id, $localKey, $morphClass)
    {
        $this->morphType = $type;
        //$this->morphClass = $parent->getMorphClass();    //注释这一行
        $this->morphClass = $morphClass;
        parent::__construct($query, $parent, $id, $localKey);
    }

其它方法和属性参考MorphOneOrMany和MorphOne。

4、新定义一个relation,例如叫multiMorphOne:

    public function multiMorphOne($related, $name, $type = null, $id = null, $localKey = null, $morphClass = null)
    {
        $instance = $this->newRelatedInstance($related);

        list($type, $id) = $this->getMorphs($name, $type, $id);

        $table = $instance->getTable();

        $localKey = $localKey ?: $this->getKeyName();

        return new MorphOne($instance->newQuery(), $this, $table.'.'.$type, $table.'.'.$id, $localKey, $morphClass);
    }

收工

7年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!