Yii2关联查询用法

本文介绍如何在两个表(post和category)间进行关联查询。通过在Post模型中定义getCate方法实现一对一关联,并提供getPostsByCategory静态方法来获取指定分类的所有文章。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

有两张表,post和category,post.cate_id对应category.id

使用Gii上升这两张表的model

然后post的model中有如下代码

  1. public function getCate()
  2. {
  3. return $this->hasOne(Category::className(), ['id' => 'cate_id']);
  4. }

 

在post这个model最下面在添加如下方法即可获取关联表内容

  1. public static function getPostsByCategory($cate_id)
  2. {
  3. return Post::find()
  4. ->joinWith('cate')
  5. ->where(['post.cate_id'=>$cate_id])
  6. ->asArray()
  7. ->all();
  8. }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值