【问题标题】:Retrieve a CActiveDataProvider with a criteria in yii在 yii 中检索具有条件的 CActiveDataProvider
【发布时间】:2012-05-19 13:55:18
【问题描述】:

我从 yii 开始,在尝试使用条件过滤 CActiveDataProvider 时遇到了一些麻烦。

这是我的数据库模型:

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

我希望 index 操作显示所有 status=finished 的项目或用户当前分配给该项目的位置。

因此为了测试目的对用户 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,
    ));

但它会抛出一个异常,说 Unknown column '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

【问题讨论】:

  • 提供完整的错误信息,包括触发它的 SQL 查询。
  • 是的,需要确切的 sql 和错误消息
  • 表中没有触发器。我要再次检查错误
  • 没有加入,你确定你有关系吗?请确保您的问题代码中没有错别字

标签: php mysql yii


【解决方案1】:

试试这个

$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,
));

【讨论】:

    猜你喜欢
    • 2014-01-16
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2011-06-01
    • 1970-01-01
    相关资源
    最近更新 更多