gpt4 book ai didi

php - 在 yii 中检索具有条件的 CActiveDataProvider

转载 作者:可可西里 更新时间:2023-11-01 06:56:55 26 4
gpt4 key购买 nike

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

这是我的数据库模型:

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

我希望 index 操作显示所有状态为已完成的项目或用户当前分配给该项目的位置。

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

最佳答案

试试这个

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

关于php - 在 yii 中检索具有条件的 CActiveDataProvider,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10665762/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com