个人博客原文:http://www.lampnick.com/php/211
yii2 联表查询的时候,会出现主键覆盖的问题,采用indexBy()中传匿名函数解决。
在打印原始sql的时候,到数据库中查询出来有44条记录,但是通过程序取出来只有1条记录。
先记录一下,详细的原因后续再看底层代码。
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;
}

本文介绍了一个在使用Yii2框架进行联表查询时遇到的问题,即查询结果出现主键覆盖的情况。通过使用indexBy方法结合匿名函数解决了该问题,并展示了具体的实现代码。

954

被折叠的 条评论
为什么被折叠?



