NOTORM PHP中的OR运算符

时间:2015-09-05 16:27:20

标签: php mysql notorm

两个表定义如下:

----------   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运算符来获取所有在数组中给出的子类型的类型。

0 个答案:

没有答案