dounai9592 2015-07-04 03:11 采纳率: 100%
浏览 60
已采纳

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

I have created a foreach loop to add data to a MySQL database and I am receiving the error "mysqli::query(): Couldn't fetch mysqli" after the first line has been added to the database.

PHP DB CONNECTION

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

I then have another chunk of script which collects the data I require. The data is then added to the foreach insert loop

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();

}

The first line is added to the database without a problem. The second line and every line after that one returns "mysqli::query(): Couldn't fetch mysqli on line 170".

Any ideas where I may be going wrong?

  • 写回答

1条回答 默认 最新

  • dongyanfeng0546 2015-07-04 03:13
    关注

    The problem may be the $db->close() inside the loop. Try closing the database after the loop.

        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();
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 下图接收小电路,谁知道原理
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度