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

Używanie CodeIgniter get_where do łączenia instrukcji „i” i „lub”

Od wersji Codeigniter 3.0 klasa konstruktora zapytań obsługuje Grupowanie zapytań

z dokumentów:

$this->db->select('*')->from('my_table')
        ->group_start()
                ->where('a', 'a')
                ->or_group_start()
                        ->where('b', 'b')
                        ->where('c', 'c')
                ->group_end()
        ->group_end()
        ->where('d', 'd')
->get();

// Generates:
// SELECT * FROM (`my_table`) WHERE ( `a` = 'a' OR ( `b` = 'b' AND `c` = 'c' ) ) AND `d` = 'd'

Edytuj: w twoim przykładzie użyjesz:

$this->db->select('message, created')->from('logs')
        ->where('username', 'user')
        ->group_start()
                ->where('created >', '1487695796')
                ->where('created <', '1487782196')
        ->group_end()
        ->group_start()
                ->where('message', 'login failure')
                ->or_where('message', 'login success')
                ->or_where('message', 'log out')
        ->group_end()               
        ->order_by('created', 'ASC')  
->get(); 

lub

$this->db->select('message, created')
        ->group_start()
                ->where('created >', '1487695796')
                ->where('created <', '1487782196')
        ->group_end()
        ->group_start()
                ->where('message', 'login failure')
                ->or_where('message', 'login success')
                ->or_where('message', 'log out')
        ->group_end()               
        ->order_by('created', 'ASC')  
->get_where('logs', array('username' => 'user') );

// both generate:
//SELECT `message`, `created` 
//FROM `logs` 
//WHERE `username` = 'user' 
//AND ( `created` > '1487695796' AND `created` < '1487782196' ) 
//AND ( `message` = 'login failure' OR `message` = 'login success' OR `message` = 'log out' ) 
//ORDER BY `created` ASC

aby sprawdzić, czy zapytanie wygenerowane przez Codeigniter pasuje do Twojego SQL, możesz użyć:

echo $this->db->last_query(); // echos last query string


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Jak wstawić DateTime do bazy danych MySql za pomocą kodu C#?

  2. Uruchom, aby po cichu zignorować / usunąć zduplikowane wpisy na INSERT

  3. mysql:Nie możemy utworzyć wyzwalaczy na tabelach systemowych?

  4. Jak zmienić nazwę schematu MySQL?

  5. Regex pasujący do komentarzy MySQL