Yii2 联表查询的时候,会出现主键覆盖的问题,采用indexBy()中传匿名函数解决。

个人博客原文:http://www.lampnick.com/php/211

yii2 联表查询的时候,会出现主键覆盖的问题,采用indexBy()中传匿名函数解决。

在打印原始sql的时候,到数据库中查询出来有44条记录,但是通过程序取出来只有1条记录。

先记录一下,详细的原因后续再看底层代码。

%e4%b8%bb%e9%94%ae%e9%87%8d%e5%a4%8d

 

public function searchProj($appcode, $proj_name, $org_id, $limit = 100)
 {
 $where['p_project_status.appcode'] = $appcode;
 if (!empty($org_id)) {
 $where['org_id'] = $org_id;
 }
 $query = PProjectStatusEntity::find();
 $query->select("p_project_status.org_id, p_project_common.ProjName,p_project_common.p_projectId,p_project_status.status");
 $query->rightJoin("p_project_common", "p_project_common.org_id = p_project_status.org_id AND p_project_common.p_projectId = p_project_status.proj_id");
 $query->andFilterWhere($where);
 $query->andFilterWhere(['like', 'p_project_common.ProjName', $proj_name]);
 $query->limit($limit);
 //echo $query->createCommand()->getRawSql();exit;
 $res = $query->indexBy(function ($row) {
 return $row['org_id'] . '___' . $row['p_projectId'];
 })->asArray()->all();
 print_r($res);
 exit;
 }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值