Laravel多态关联的介绍(附代码)

互联网 19-3-22
本篇文章给大家带来的内容是关于Laravel多态关联的介绍(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

Laravel 多态关联(morphTo,morphMany)

在网站开发的过程中,经常会遇到 评论商品,评论文章, 评论店铺 等等,在处理这样的需求的时候, 经常会新建一张 评论表, 然后通过 一个 type字段来区分 评论的对象 开发过程如下:

新建表操作

php artisan make:model Models/Comments -m

表字段:

 public function up()     {         Schema::create('comments', function (Blueprint $table) {             $table->increments('id');             $table->timestamps();             $table->integer('member_id');             $table->string('comment_object_type');   # 评论对象             $table->integer('comment_object_id');    # 评论对象的id             $table->text('comment_content');         # 评论内容             $table->tinyInteger('status');         });     }

做数据迁移:

php artisan migrate
INSERT INTO `comments`(`member_id`,`comment_object_type`,`comment_object_id`,`status`,`created_at`,`updated_at`) VALUES (2,'App\\Models\\Goods',1,0,'2018-09-07 15:58:04','2018-09-07 15:58:04'), (2,'App\\Models\\Goods',2,0,'2018-09-07 15:58:04','2018-09-07 15:58:04'), (2,'App\\Models\\Goods',3,0,'2018-09-07 15:58:04','2018-09-07 15:58:04'), (2,'App\\Models\\Goods',4,0,'2018-09-07 15:58:04','2018-09-07 15:58:04'), (4,'App\\Models\\Goods',3,0,'2018-09-07 15:58:04','2018-09-07 15:58:04'), (3,'App\\Models\\Goods',4,0,'2018-09-07 15:58:04','2018-09-07 15:58:04')

2.用户ID 为2 的用户 对 店铺ID 为 1,4 的 店铺进行了评论

INSERT INTO `comments`(`member_id`,`comment_object_type`,`comment_object_id`,`status`,`created_at`,`updated_at`) VALUES (2,'App\\Models\\Stores',1,0,'2018-09-07 15:58:04','2018-09-07 15:58:04'), (2,'App\\Models\\Stores',4,0,'2018-09-07 15:58:04','2018-09-07 15:58:04'),

查询数据造完毕, 接下来要做查询,查询一下 商品id为2的 所有评论, 并且查询出评论人的信息普通查询:

public function comment_list(Requset $request, Goods $goods)   {         # 查询商品的所有评论         $comments = Comment::where('comment_object_type',Goods::class)->where('comment_object_id',$goods->id)->get();        if($comments) {           foreach($comments as $comment) {                  $comment->member = Member::find('id',$comment->member_id)                }        }        dd($comments)    }

普通连表查

Comment.php 文件
# Comment model 文件修改          # 查找评论的用户的信息        public function member()         {             return $this->belongsTo(Member::class, 'comment_member_id');         }

需求的查询

 public function comment_list(Requset $request, Goods $goods)   {         # 查询商品的所有评论         $comments = Comment::where('comment_object_type',Goods::class)->where('comment_object_id',$goods->id)->get();         # 省掉了 循环 在模板遍历的时候 直接调用  $item->member 查看用户信息        dd($comments)    }

多态查询

Comment.php 文件
# Comment model 文件修改  # 评论对象     public function comment_object()     {         return $this->morphTo();     }     # 查找评论的用户的信息    public function member()     {         return $this->belongsTo(Member::class, 'comment_member_id');     }
Goods.php 文件
# 商品关联评论     public function comments()     {         return $this->morphMany(Comment::class,self::class,'comment_object_type','comment_object_id');     }

需求的查询

public function comment_list(Requset $request, Goods $goods)  {         # 查询商品的所有评论         $comments =$goods->comments()->with('member')->paginate(15);         dd($comments)  }

本篇文章到这里就已经全部结束了,更多其他精彩内容可以关注PHP中文网的php视频教程栏目!

以上就是Laravel多态关联的介绍(附代码)的详细内容,更多内容请关注技术你好其它相关文章!

来源链接:
免责声明:
1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表本站的观点或立场
标签: laravel
上一篇:php获取远程图片并下载保存到本地的方法分析 下一篇:如何在Laravel5中清除缓存

相关资讯