sql >> Databasteknik >  >> RDS >> Mysql

CodeIgniter Databas Query med query() med IN-sats

Det är korrekt beteende. CI undviker citat innan de skickas till MySQL. Du bör förmodligen använda en array för filtret och konstruera något sånt här (ej testat;) )

$filter = array('a','b','c');
$sql = "SELECT t1.*, t2.* 
     FROM Table1 t1 
     INNER JOIN Table2 t2 
         ON  t1.id = t2.id 
         AND t2.title IN (". implode(',', array_fill(0, count($filter), '?')).") 
         AND t1.type = ? 
     ORDER BY t1.id";
//edit: check if $filter is not an array ( when it is a single value string )
$filter = is_array( $filter ) ? $filter : array( $filter );
$q = $this->db->query( $sql, array_merge( $filter, array( $type ) ) );

Du bör också skriva om frågan lite:

$sql = "SELECT t1.*, t2.* 
     FROM Table1 t1 
     INNER JOIN Table2 t2 
         ON  t1.id = t2.id 
     WHERE
         t2.title IN (". implode(',', array_fill(0, count($filter), '?')).") 
         AND t1.type = ? 
     ORDER BY t1.id";



  1. Hur skickar man värden till IN-operatören dynamiskt?

  2. Bestäm radstorleken för tabellen

  3. Formler för att beräkna geografisk närhet

  4. Hur infogar man specialtecken i en databas?