我从yii开始,在尝试使用条件过滤CActiveDataProvider时遇到了一些麻烦.
这是我的数据库模型:
Table Columns
Project [id,name,status]
userToProject [user_id,project_id,role]
User [id,....]
我希望索引操作能够显示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,));
但它引发了一个异常,称未知列’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
最佳答案
试试这个
$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,));
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。