1

我正在尝试以 CActiveDataProvider 样式获取数据,以便将数据传递给相应视图中的 CGridView。

我尝试以这种方式使用 CActiveData Provider 获取关系数据:

  1. 我有三个表如下:

    CREATE TABLE tbl_test_location( locationIdint(11) NOT NULL AUTO_INCREMENT, locationNamevarchar(255) DEFAULT NULL, PRIMARY KEY ( locationId)) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8;

    CREATE TABLE tbl_test_user( userIdint(11) NOT NULL AUTO_INCREMENT, userNamevarchar(255) DEFAULT NULL, PRIMARY KEY ( userId)) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;

    创建表tbl_test_location_user_assignmentlocationIdint(11)NOT NULL, userIdint(11)NOT NULL,主键(locationIduserId),键fk_tlua_useruserId),约束外fk_tlua_location键(locationId)引用tbl_test_locationlocationId)删除级联,约束外fk_tlua_user键(userId)引用tbl_test_useruserId)删除级联) 引擎=InnoDB 默认字符集=utf8;

  2. 模型中的关系是:

/models/TestLocation.php

'tblTestUsers' => array(self::MANY_MANY, 'TestUser', '{{test_location_user_assignment}}(locationId, userId)'),

/models/TestUser.php

'tblTestLocations' => array(self::MANY_MANY, 'TestLocation', '{{test_location_user_assignment}}(userId, locationId)'),
  1. 控制器中名为 actionIndexOwn 的方法是: 注意:用户可以有多个位置,一个位置可以有多个用户。

/controllers/TestLocationController.php

public function actionIndexOwn() { $dataProvider=new CActiveDataProvider('TestLocation', array( 'criteria'=>array( 'with'=>array( 'tblTestUsers'=>array( 'condition'=>'tbl_test_user.userId=1', ), ), ), )); $this->render('index',array( 'dataProvider'=>$dataProvider, )); }

  1. 观点是:

意见/testLocation/index.php

<?php $this->widget('zii.widgets.CListView', array( 'dataProvider'=>$dataProvider, 'itemView'=>'_view', )); ?>

我收到了这个错误:

CDbCommand failed to execute the SQL statement: SQLSTATE[42S22]: Column not found: 1054 Unknown column 'tbl_test_user.userId' in 'where clause'. The SQL statement executed was: SELECT COUNT(DISTINCT `t`.`locationId`) FROM `tbl_test_location` `t` LEFT OUTER JOIN `tbl_test_location_user_assignment` `tblTestUsers_tblTestUsers` ON (`t`.`locationId`=`tblTestUsers_tblTestUsers`.`locationId`) LEFT OUTER JOIN `tbl_test_user` `tblTestUsers` ON (`tblTestUsers`.`userId`=`tblTestUsers_tblTestUsers`.`userId`) WHERE (tbl_test_user.userId=1)

应用程序日志:

CDbCommand::fetchColumn() failed: SQLSTATE[42S22]: Column not found: 1054
Unknown column 'tbl_test_user.userId' in 'where clause'. The SQL statement
executed was: SELECT COUNT(DISTINCT `t`.`locationId`) FROM
`tbl_test_location` `t`  LEFT OUTER JOIN
`tbl_test_location_user_assignment` `tblTestUsers_tblTestUsers` ON
(`t`.`locationId`=`tblTestUsers_tblTestUsers`.`locationId`) LEFT OUTER JOIN
`tbl_test_user` `tblTestUsers` ON
(`tblTestUsers`.`userId`=`tblTestUsers_tblTestUsers`.`userId`) WHERE
(tbl_test_user.userId=1).
in C:\htdocs\RackDomain\protected\views\testLocation\index.php (20)
in C:\htdocs\RackDomain\protected\controllers\TestLocationController.php
(147)

有人可以帮助我吗,我尝试了很多方法来编写关系 CActiveDataProvider 但我总是得到同样的错误......

非常感谢你的帮助!

4

2 回答 2

1

如果您想使用关系数据字段,只需将关系名称与字段名称一起使用。

$dataProvider=new CActiveDataProvider('TblTestLocation', array(
            'criteria'=>array(
                'with'=>array(
                    'tblTestUsers'=>array(
                        'condition'=>'tblTestUsers.userId=1',
                    ),
                ),
            ),
        ));

这里“tblTestUsers”是模型类中定义的关系名称。

于 2015-08-04T09:18:39.940 回答
1

正如你所看到的错误,Yii 在它的 sql 查询中使用了表名的别名。所以你也应该使用这个别名。更重要的是,将表名、列名和别名放入其中``更不容易出错。

您的代码应如下所示:

public function actionIndexOwn()
{
    $dataProvider=new CActiveDataProvider('TestLocation', array(
        'criteria'=>array(
            'with'=>array(
                'tblTestUsers'=>array(
                    'condition'=>'`tblTestUsers`.`userId`=1',
                ),
            ),
        ),
    ));
    $this->render('index',array(
        'dataProvider'=>$dataProvider,
    ));
}
于 2015-08-04T08:11:14.470 回答