我有三个表 - myusers,organisation_classrooms,organisation_classrooms_myusers(这是organisation_classrooms和myusers表之间的数据透视表)
organisation_classrooms(classroom_id,organisation_id,title) organisation_classrooms_myusers(classroom_id,user_id) myusers(user_id,organisation_id,fullname)
我的一个模型中有以下search()函数:
return new CActiveDataProvider(OrganisationClassroom::model()->currentUserOrganisation(), array(
'criteria' => $criteria,
'pagination' => array(
'pageSize' => 10,
)
));
这是我正在使用的数据集
organisation_classrooms
classroom_id title organisation_id
1 Class A 37383
2 Class B 37383
3 Class C 37383
organisation_classrooms_myusers
classroom_id user_id
2 1558
3 1558
myusers
user_id organisation_id name
1558 37383 Bob Doe
我想修改模型,以便对于属于组织的每个organisation_classroom,检查organisation_classrooms_myusers数据透视表中是否存在user_id 1558,并基本上设置一个布尔值
e.g
我希望通过上面用于1558的user_id的organisation_classrooms CActiveDataProvider返回以下数据
classroom_id title organisation_id pivot_set
1 Class A 37383 0
2 Class B 37383 1
3 Class C 37383 1
有人可以建议怎么做吗?或者,如果任何人都可以演示一个原始SQL查询,它将产生这个非常有用的结果。
答案 0 :(得分:1)
在“组织课堂myuser”中添加列“id”(主键)。
SELECT room.classroom_id,room.title,room.organisation_id, if(rela.user_id,1,0) AS pivot_set FROM `organisation_classrooms` AS room LEFT JOIN organisation_classrooms_myusers AS rela ON rela.classroom_id = room.classroom_id
答案 1 :(得分:0)
我在另一个让我走向正确方向的网站上找到了这个 - 如果它对其他人有帮助的话:
// CDbCriteria $criteria already prepared given other search criteria, then: */
$criteria->select = 't.classroom_id, t.title, t.organisation_id, case when cu.classroom_id is null then 0 else 1 end as pivot_set';
$criteria->join = 'left join organisation_classrooms_myusers cu on cu.classroom_id=t.classroom_id and cu.user_id=:uid';
$criteria->params['uid'] = $uid; /* e.g. 1558 */