2012-05-19 7 views
5

私はyiiから始まり、条件付きでCActiveDataProviderをフィルタリングしようとするといくつか問題があります。yiiの基準を持つCActiveDataProviderを取得します。

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

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

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

テスト目的でユーザー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 
+1

を試してみて、それをトリガーSQLクエリを含む完全なエラーメッセージを、提供します。 – DCoder

+0

はい正確なSQLとエラーメッセージが必要です –

+0

私はテーブルにトリガを持っていません。私は再びエラーを確認するつもりです – Addev

答えて

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, 
)); 
関連する問題