两个表定义如下:
---------- 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 运算符放在两者之间以获取所有具有数组中给定子类型的类型。