PDO查询不返回PHP foreach循环中的结果

时间:2015-05-12 18:27:14

标签: php mysql pdo foreach

我有一个函数(下面),它没有从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)

1 个答案:

答案 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);
    }
}