我正在处理一个连接查询,在该查询中我必须从包含逗号分隔值的列中获取数据。比如allowed_activity
包含1,2,3,4,5,6
这个activity_id
是允许的。
因此,在查询中,我正在检查是否允许当前活动,为此,我已经使用where_in
并find_in_set
在where
条件下进行了尝试。
这是查询的那一部分:
$this->db->where_in('a.allowed_activity',$activity_id);
//And With FIND_IN_SET
$this->db->where("FIND_IN_SET($activity_id, a.allowed_activity) !=",0);
问题或困惑
当我使用where_in
它并没有给我结果。但如果我使用 FIND_IN_SET
它,它将返回所需的结果。我认为这where_in
可以完成任务,但事实并非如此。
只是想知道为什么
find_in_set
工作方式不同于where_in
因为这两个功能的工作方式与查找数据相同,都在逗号分隔的列表中。
这是完整的查询:
SELECT mycolumns
FROM `table1` as `ea`
LEFT OUTER JOIN `table2` as `a` ON `ea`.`package_id` = `a`.`id`
LEFT OUTER JOIN `table3` as `e` ON `ea`.`employer_id` = `e`.`id`
WHERE `ea`.`card_id` > 0
AND FIND_IN_SET(6, a.allowed_activity) !=0
AND `ea`.`id` = '6'
ORDER BY `ea`.`creation_date` DESC
我正在使用 Codeigniter 活动记录。