0

两个表定义如下:

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

4

0 回答 0