我有一个函数(下面),它没有从foreach循环中的PDO查询返回结果集。不确定可能是什么问题。为了解释一下,我正在运行PHP v5.6.3并且传递给该函数的$ csv字符串是这样的:
$csv = "red, brown, blue";
运行str_getcsv后,print_r($ colors)按预期工作。我已经尝试在循环内部或外部准备查询和绑定值,但没有成功,如果我将查询拉出循环(并运行一次),它就可以工作。
function generateColors($csv) {
global $db; // Connect DB
$colors = str_getcsv($csv, ","); //Converts the CSV to an array
$query = $db->prepare("SELECT * FROM colors WHERE slug = :slug");
foreach ($colors as $slug) {
$query->bindValue(':slug', $slug, PDO::PARAM_STR);
$query->execute();
$result = $query->fetch(PDO::FETCH_ASSOC);
echo "COLOR: " .$slug;
echo "<br>";
var_dump($result);
}
}
输出(如下)显示循环正在运行,只是查询似乎在1次迭代后停止返回值。任何关于为什么我得到一个bool(false)而不是像[column 1] =&gt; value 1,[column 2] =&gt; value 2等数组那样的帮助将不胜感激。
COLOR: red
array -> [column]=>value, [column]=value, etc. // returned as expected.
COLOR: brown
bool(false)
COLOR: blue
bool(false)
答案 0 :(得分:1)
你应该绑定foreach内的params。在foreach之前,您的变量$slug
未定义。
function generateColors($csv) {
global $db; // Connect DB
$colors = str_getcsv($csv, ","); //Converts the CSV to an array
$query = $db->prepare("SELECT * FROM colors WHERE slug = :slug");
foreach ($colors as $slug) {
$query->bindValue(':slug', $slug, PDO::PARAM_STR);
$query->execute();
$result = $query->fetch(PDO::FETCH_ASSOC);
echo "COLOR: " .$slug;
echo "<br>";
var_dump($result);
}
}