我有以下方法:
public function actionIndex() {
$companyModel = Company::model()->findAll();
$supplierProductModel = SupplierProduct::model()->findAll();
$this->render('index', array(
'companyData' => $companyModel,
'supplierProductData' => $supplierProductModel,
));
}
在这里,我已经将模型对象传递给了呈现函数,并希望访问视图中的这些对象(活动关系类型),但当我访问视图中时,它显示错误:
Trying to get property of non-object
查看文件(index.php)
echo $companyData->name . "'n";
echo $this->companyModel->phone . "'n";
echo $this->companyModel->fax . "'n";
echo $this->companyModel->cell . "'n";
如有任何帮助,我们将不胜感激。
您需要在控制器/操作中声明$this->companyModel
$this->companyModel = Company::model()->findByPk($companyId);
使用Company::model()->findAll(),您可以在视图文件中迭代一组公司模型。
foreach ($companyData as $companyModel) {
var_dump($companyModel->attributes);
}
这是因为findAll()
findAll()在多维数组中重新运行公司表的所有行,因此这里$companyData是多维数组,现在更改索引中的代码,如下图、
<?php
foreach ($companyData as $compSub)
{
echo $compSub->name . "'n";
echo $compSub->phone . "'n";
echo $compSub->fax . "'n";
echo $compSub->cell . "'n";
}
?>
如果您想要公司数据(单行),请像以下一样更改您的查询
$companyModel = Company::model()->findByPk($id_Of_company);
//$companyModel is single dimensional array, it has all the info of a company.
发送此以查看
$this->render('index', array(
'companyData' => $companyModel,
....................
));
现在您可以使用以下代码显示数据
echo $companyData->name . "'n";
echo $companyData->phone . "'n";
echo $companyData->fax . "'n";
echo $companyData->cell . "'n";
您正试图从数据库中获取所有条目,因为findAll()返回多维对象数组中的所有数据。如果您需要所有的条目,您可以在视图文件中对其进行迭代,并获得如所示的结果
在视图文件中,按所示操作
<?php foreach($companyData as $value){
echo $vlaue->name . "'n";
echo $value->phone . "'n";
echo $value->fax . "'n";
echo $value->cell . "'n";
?>
有了这个,你可以从表中获得所有条目
如果您想使用Cdbcriteria获得特定的记录使用条件,并传递对象并获得单个结果