两个表定义如下:
---------- types -----------
id type
1 A
2 B
3 C
---------- subtypes ----------
id type_id sub_type
1 1 sub_type1
2 2 sub_type1
3 3 sub_type2
4 1 sub_type3
5 2 sub_type2
我的PHP NOTORM代码如下:
$query = $db->types();
$subTypeFilters = ['sub_type1','sub_type3'];
function filteredQuery($subTypeFilters , $query){
global $db;
$subTypeQuery ;
for($i = 0 ; $i < count($subTypeFilters); $i++){
// if($i>0)
// $subTypeQuery .= ' OR ' ;
$subTypeQuery = $query('id' , $db->sub_type()->where('sub_type', $subTypeFilters[$i])->select('type_id'));
}
echo ($subTypeQuery);
return $subTypeQuery;
}
$query = filteredQuery($subTypeFilters , $query);
我得到$ subTypeQuery为select * from types where (id in (1,2)) AND (id in (1))
所以最后我最终只得到一个id = 1的类型,我怎样才能在其间放置OR运算符来获取所有在数组中给出的子类型的类型。