我正在嘗試在數據庫中查詢“product_id”包含在產品ID數組中的記錄.
該數組是多選輸入(< select>)的結果,如下所示:
$clients =
Array (
[0] => 80000016-1302638679
[1] => 8000003B-1329924004
)
我想將該數組傳遞給sql語句的“IN”子句,例如:
$sql = "SELECT * FROM sales WHERE product_id IN (".$clients.")";
…但這不起作用(錯誤:消息:數組到字符串轉換).
一些帖子建議使用此函數以適合sql的方式格式化數組:
function format_array($array){
return implode(',',$array);
}
}
如 …
$sql = "SELECT * FROM sales WHERE product_id IN (".format_array($clients).")";
這導致了這個查詢:
SELECT * FROM sales WHERE product_id IN(80000016-1302638679,8000003B-132992400)
……而且這個錯誤:
‘where子句’中的未知列’8000003B’
我究竟做錯了什么?任何幫助是極大的贊賞!如果需要,我可以澄清這個問題:)