2011-04-01 28 views
11

我的作業有一個問題,例如有一個類別數組$ cat = array('1','4','5','7');現在我需要從基於類別的數據庫中選擇產品SQL選擇數組中的所有內容

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

是否有可能在單個查詢中執行此操作?因爲四個查詢的最終結果將被結合。

回答

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; 

它更通用的,將適合任何陣!

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