Możesz to zrobić ręcznie, jak podano tutaj :
Jeśli chodzi o twoje pytanie:
$this->db->where("category = 1 AND (category = 2 OR category = 3)");
W 3.0-dev :
$this->db->select()
->group_start()
->or_like([ 'category' => 2, 'category' => 3 ])
->group_end()
->where([ 'category' => 1 ]);
aktualizacja
Zobacz odpowiedzi na to pytanie
jeśli używasz CI 2.2. Wybierz odpowiedź inną niż zaakceptowana .
Lub po prostu wypróbuj to :
$categories = array(2, 3);
array_walk($categories, function(&$cat) { $cat = 'category = ' . $cat; });
$catstring = implode(" OR ", $categories);
$where = "category = 1 AND ($catstring)";
// => category = 1 AND (category = 2 OR category = 3)
$this->db->where($where);