在yii中使用CActiveDataProvider获取数据

时间:2010-12-06 14:33:38

标签: sql yii

我有3张桌子,标准关系MANY-TO-MANY 用户(id,...) - > Users_Has_Courses(Users_id,Courses_id) - >课程(ID,...)

课程模型有下一个关系

'users' => array(self::MANY_MANY, 'Users', 'users_has_courses(Courses_id, Users_id)')

用户模型具有下一个关系

'courses' => array(self::MANY_MANY, 'Courses', 'users_has_courses(Users_id, Courses_id)')

请说明如何获取具有指定“id”的用户尚未使用CActiveDataProvider订阅的课程列表? 换句话说,我需要这个简单的SQL查询的类比

select * from Courses where id not in (select Courses_id from users_has_courses where Users_id = 2)

感谢您的帮助

1 个答案:

答案 0 :(得分:5)

尝试使用参数化的命名范围来封装查询,而不是常规的“关系”。在您的课程模型中,添加此范围函数以获取用户不在的所有课程的列表:

public function userNotIn($user_id)
{
  $criteria=new CDbCriteria();
  $criteria->condition .= 't.id NOT IN (SELECT users_has_courses.Courses_id FROM users_has_courses WHERE users_has_courses.Users_id = :userid)';
  $criteria->params[':userid'] = $user_id;
  $this->getDbCriteria()->mergeWith($criteria);
  return $this;
}

然后你应该能够做到这一点:

$coursesNotIn=new CActiveDataProvider(Courses::model()->userNotIn($user->id));

此代码完全未经测试,但原则上应该有效。当我有一个复杂的查询时,我经常这样做,但我仍然想使用AR功能,如CActiveDataProvider。在此处阅读有关“命名范围”的更多信息:

http://www.yiiframework.com/doc/guide/1.1/en/database.ar#parameterized-named-scopes

祝你好运!