sql >> Databasteknik >  >> RDS >> Mysql

CodeIgniter Active Record - Grupp ELLER uttalanden

Du kan göra det manuellt som anges här :

När det gäller din fråga:

$this->db->where("category = 1 AND (category = 2 OR category = 3)");

I 3.0-dev :

$this->db->select()
->group_start()
->or_like([ 'category' => 2, 'category' => 3 ])
->group_end()                
->where([ 'category' => 1 ]);

uppdatering

Se svaren på denna fråga om du använder CI 2.2. Välj ett annat svar än det godkända .

Eller prova helt enkelt detta :

$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);


  1. Hur man avrundar siffror i databasen till två decimaler med en MySql-fråga

  2. Använder Amazon RDS med Android-applikation

  3. Hur genererar jag ett slumpmässigt tidsintervall och lägger till det i en mysql datetime med php?

  4. Skiftlägeskänslig där uttalande i laravel