Mysql
 sql >> Baza danych >  >> RDS >> Mysql

CodeIgniter Active Record - grupowe zestawienia OR

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


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Dlaczego runda MySQL płynie o wiele bardziej niż oczekiwano?

  2. Podziel ciągi za pomocą mysql

  3. Jak wybrać każdy n-ty wiersz w mySQL, zaczynając od n

  4. Dlaczego ta funkcja przechowywana w MySQL daje inne wyniki niż wykonanie obliczeń w zapytaniu?

  5. C# Zbyt wiele połączeń w MySQL