5

私はyiiから始めていますが、CActiveDataProviderを条件でフィルタリングしようとすると問題が発生します。

これは私のデータベースモデルです:

Table            Columns
Project          [id, name, status]
userToProject    [user_id,project_id,role]
User             [id , ....]

また、インデックスアクションで、status = finishのすべてのプロジェクト、またはユーザーが現在そのプロジェクトに割り当てられている場所を表示したいと思います。

したがって、テスト目的でユーザーIDをハードコーディングします。これは私のコードです:

$criteria=array(
            'order'=>'status desc',
            'with'=>array(
               'userToProject','userToProject.user'=>array('alias'=>'user')),
    );
$criteria['condition']='status=='.Project::STATUS_FINISHED;
$criteria['condition'].=' OR user.id = 6';
$dataProvider=new CActiveDataProvider('Project', array(
            'criteria'=>$criteria,
    ));
$this->render('index',array(
            'dataProvider'=>$dataProvider,
    ));

ただし、不明な列'user.idという例外がスローされます。私は何が欠けていますか?ありがとう

編集:エラーコードは次のとおりです。

 Column not found: 1054
 Unknown column 'users.user_id' in 'where clause'. The SQL statement executed was: 
 SELECT `t`.`id` AS `t0_c0`, `t`.`name` AS `t0_c1`, `t`.`description` AS `t0_c2`, 
 `t`.`status` AS `t0_c3`, `t`.`creation_date` AS `t0_c4` FROM `pgp_project` `t` WHERE
  (status=4 OR users.user_id=6) ORDER BY status desc LIMIT 10
4

1 に答える 1

14

これを試して

$criteria=new CDbCriteria(array(                    
    'order'=>'status desc',
    'with'   => array('userToProject'=>array('alias'=>'user')),
    'condition'=>'status='.Project::STATUS_FINISHED.' OR user.id = 6',
));

$dataProvider=new CActiveDataProvider('Project', array(
    'criteria'=>$criteria,
));

$this->render('index',array(
    'dataProvider'=>$dataProvider,
));
于 2012-05-19T15:37:58.450 に答える