我的 Yii 应用程序中有 2 个表;类别和项目。
Category
- id
- name
Item
- id
- category_id
- name
我想做的是获取类别表中的项目列表,然后计算项目表中每个类别的项目数。
我正在使用 CActiveDataProvider 检索 Category 表中的项目列表,然后使用 for 循环来计算每个类别中的项目数。但是,我似乎无法弄清楚如何将数组与我的 DataProvider 数据项合并。
到目前为止,这是我的代码。
public function actionIndex()
{
$dataProvider = new CActiveDataProvider('Category', array(
'criteria' => array(
'select' => 'id, name, slug',
'order' => 'name ASC',
),
));
$dataProvider->setPagination(false);
$count = array();
foreach($dataProvider->getData() as $categoryData) {
$count[] = Item::model()->count("category_id = :categoryID", array("categoryID" => $categoryData->id));
}
$this->render('index', array(
'dataProvider' => $dataProvider,
'count' => $count,
));
}
如何将 $count 数组与我现有的 dataProvider 数据项合并,以便我可以将它与 CListView 一起使用?还有比这更好的解决方案吗?