Estoy comenzando con yii y tengo algunos problemas al intentar filtrar un CActiveDataProvider con un criterio.Recupere un proveedor de datos de CActive con un criterio en yii
Ésta es mi modelo de base de datos:
Table Columns
Project [id, name, status]
userToProject [user_id,project_id,role]
User [id , ....]
y me gustaría que el índice de acción para mostrar todos los proyectos con estado = terminado o donde el usuario está actualmente asignado a ese proyecto.
Así que codifique la identificación de usuario para fines de prueba. Este es mi código:
$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,
));
Pero se produce una excepción diciendo columna Desconocido 'user.id. ¿Qué me estoy perdiendo? Gracias
Editar: El código de error es:
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
Proporcionar el mensaje de error completo, incluyendo la consulta SQL que lo activa. – DCoder
sí, el sql exacto y el mensaje de error serían necesarios –
No tengo desencadenantes en las tablas. Voy a verificar el error de nuevo – Addev