gpt4 book ai didi

php - mysqli::query(): 在 foreach 循环的第一行之后无法获取 mysqli

转载 作者:行者123 更新时间:2023-11-29 12:07:35 30 4
gpt4 key购买 nike

我创建了一个 foreach 循环来将数据添加到 MySQL 数据库,但在将第一行添加到数据库后,我收到错误“mysqli::query(): Couldn't fetch mysqli”。

PHP 数据库连接

$db = new mysqli($db_hostname, $db_username, $db_password, $db_database);
if ($db->connect_error) {
die("Connection failed: " . $db->connect_error);
}

然后我有另一 block 脚本来收集我需要的数据。然后将数据添加到 foreach 插入循环

PHP FOREACH

foreach($RSS_DOC->channel->item as $RSSitem)
{

$item_id = md5($RSSitem->title);
$fetch_date = date("Y-m-j G:i:s");
$item_title = $RSSitem->title;
$item_date = date("Y-m-j G:i:s", strtotime($RSSitem->pubDate));
$item_url = $RSSitem->link;

echo "Processing item '" , $item_id , "' on " , $fetch_date , "<br/>";
echo $item_title, " - ";
echo $item_date, "<br/>";
echo $item_url, "<br/>";

$sql = "INSERT INTO rssingest (item_id, feed_url, item_title, item_date, item_url, fetch_date)
VALUES ('" . $item_id . "', '" . $feed_url . "', '" . $item_title . "', '" . $item_date . "', '" . $item_url . "', '" . $fetch_date . "')";

if ($db->query($sql) === TRUE) { // <- THIS IS LINE 170
echo "New record created successfully";
} else {
echo "Error: " . $sql . "<br>" . $db->error;
}

$db->close();

}

第一行已毫无问题地添加到数据库中。第二行和之后的每一行都返回“mysqli::query(): Couldn't fetch mysqli on line 170”。

有什么想法我可能会出错吗?

最佳答案

问题可能出在循环内的$db->close()。尝试在循环后关闭数据库。

    foreach($RSS_DOC->channel->item as $RSSitem)
{

$item_id = md5($RSSitem->title);
$fetch_date = date("Y-m-j G:i:s");
$item_title = $RSSitem->title;
$item_date = date("Y-m-j G:i:s", strtotime($RSSitem->pubDate));
$item_url = $RSSitem->link;

echo "Processing item '" , $item_id , "' on " , $fetch_date , "<br/>";
echo $item_title, " - ";
echo $item_date, "<br/>";
echo $item_url, "<br/>";

$sql = "INSERT INTO rssingest (item_id, feed_url, item_title, item_date, item_url, fetch_date)
VALUES ('" . $item_id . "', '" . $feed_url . "', '" . $item_title . "', '" . $item_date . "', '" . $item_url . "', '" . $fetch_date . "')";

if ($db->query($sql) === TRUE) {
echo "New record created successfully";
} else {
echo "Error: " . $sql . "<br>" . $db->error;
}



}
$db->close();

关于php - mysqli::query(): 在 foreach 循环的第一行之后无法获取 mysqli,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31216508/

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