gpt4 book ai didi

php - PDO 查询未在 PHP foreach 循环中返回结果

转载 作者:行者123 更新时间:2023-11-29 00:00:04 24 4
gpt4 key购买 nike

我有一个函数(如下),它不从 foreach 循环内的 PDO 查询返回结果集。不知道可能是什么问题。稍微解释一下,我正在运行 PHP v5.6.3,传递给函数的 $csv 字符串类似于:

$csv = "red, brown, blue";

运行 str_getcsv 后,print_r($colors) 将按预期工作。我已经尝试在循环内部或外部准备查询和绑定(bind)值,但没有成功,如果我将查询拉到循环外部(并运行一次),它就可以工作。

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]=>value 1、[column 2]=>value 2 等数组集的帮助,将不胜感激。

COLOR: red
array -> [column]=>value, [column]=value, etc. // returned as expected.
COLOR: brown
bool(false)
COLOR: blue
bool(false)

最佳答案

您应该在 foreach 中绑定(bind)参数。在 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);
}
}

关于php - PDO 查询未在 PHP foreach 循环中返回结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30198764/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com