• Laravel5.1 模型 --多态关联


    什么是多态关联? 一个例子你就明白了:好比如说评论 它可以属于视频类 也可以属于文章类,当有个需求是 从评论表中取到视频类的数据,这就需要用到多态关联了。

    简单的一句话总结:一张表对应两张表。


    1 实现多态关联

    1.1 文章表的结构

        public function up()
        {
            Schema::create('articles', function (Blueprint $table) {
                $table->increments('id');
                $table->string('title');
                $table->text('body');$table->timestamps();
            });
        }

    1.2 视频表结构

        public function up()
        {
            Schema::create('videos', function (Blueprint $table) {
                $table->increments('id');
                $table->string('title');
                $table->text('description');
                $table->timestamps();
            });
        }

    1.3 评论表结构

        public function up()
        {
            Schema::create('comments', function (Blueprint $table) {
                $table->increments('id');
                $table->text('content');
                $table->integer('item_id');
                $table->string('item_type');
                $table->timestamps();
            });
        }

    ↑ 这里需要指定 item_id 和 item_type 单一介绍一下 item_type 它主要是区别关联于那张表的 我们这里它只有两个值:AppArticle 或 AppVideo。

    1.4 编写多态关联

    Article 和 Video:

        public function comments()
        {
            /**
             * 第二个参数:如果你的前缀是item_ 那么就写item 如果是别的就写别的。
             * 第三个参数:item_type
             * 第四个参数:item_id
             * 第五个参数:关联到那个表的键
             * (以上除了第二个参数都可以省略)
             */
            return $this->morphMany(Comment::class, 'item', 'item_type', 'item_id', 'id');
        }

    Comment:

        public function video()
        {
            /**
             * 三个参数都可以省略 不过K建议你还是写全
             */
            return $this->morphTo('item', 'item_type', 'item_id');
        }

    使用:

    Route::get('/', function () {
        $video = AppVideo::find(8);
        foreach ($video->comments as $comment) {
            echo $comment->id . ": " . $comment->item_type;
        }
    });
  • 相关阅读:
    常见Dos命令
    常用快捷键小技巧
    springboot集成JPA返回Json报错 com.fasterxml.jackson.data
    docker安装mysql 8.0.20 版本 超详细教程
    8.24 Java自学
    8.23 Java自学
    8.22 Java自学
    8.21 Java自学
    8.20 Java自学
    8.19 Java自学
  • 原文地址:https://www.cnblogs.com/sun-kang/p/7589185.html
Copyright © 2020-2023  润新知