您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

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

2024/2/28 0:39:35发布24次查看
本篇文章给大家带来的内容是关于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
造数据
用户 id 为2和4 的用户对 商品id 为 1,2,3,4的商品进行评论:
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视频教程栏目!
以上就是laravel多态关联的介绍(附代码)的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product