2011-04-01 8 views
11

Mi tarea tiene un problema, por ejemplo, hay una matriz de categoría $ cat = array ('1', '4', '5', '7'); ahora tengo que seleccionar productos de base de datos en la categoría que esSQL seleccionar todo en una matriz

SELECT * FROM products WHERE catid='1' 
SELECT * FROM products WHERE catid='4' 
SELECT * FROM products WHERE catid='5' 
SELECT * FROM products WHERE catid='7' 

¿Es posible hacer esto en una sola consulta? ya que los resultados finales de las cuatro consultas se combinarán.

Respuesta

30
SELECT * FROM products WHERE catid IN ('1', '2', '3', '4') 
0
$SQL_Part="(" 
$i=0; 
while ($i<length($cat)-1) 
{ 
    $SQL_Part+=$cat[i]+","; 
} 
$SQL_Part=$SQL_Part+$cat[$i+1]+")" 

$SQL="SELECT * FROM products WHERE catid IN "+$SQL_Part; 

es más genérico y cabrán para cualquier matriz !!

1
// array of $ids that you need to select 
$ids = array('1', '2', '3', '4', '5', '6', '7', '8'); 

// create sql part for IN condition by imploding comma after each id 
$in = '(' . implode(',', $ids) .')'; 

// create sql 
$SQL = 'SELECT * FROM products WHERE catid IN ' . $in; 

// see what you get 
var_dump($sql); 
Cuestiones relacionadas