开发者

While loop on a mysql call is throwing unknown PDO exception 'General Error'

开发者 https://www.devze.com 2023-03-28 21:01 出处:网络
I use the following (or similar) code on hundreds of pages I have built: $stmt = $db->prepare(\"SELECT * FROM table\");

I use the following (or similar) code on hundreds of pages I have built:

$stmt = $db->prepare("SELECT * FROM table");
$stmt->execute();

while($row = $stmt->fetch()) {

    $id = $row['id'];
    $name = $row['name'];

    do something with data returned...


    $id = NULL;
    $name = NULL;

}

Out of nowwhere, I started receiving the following error on a few pages:

Fatal error: Uncaught exception 'PDOException' with message 'SQLSTATE[HY000]: General error' in C:....page.php:28 Stack trace: #0 C:..page.php(28): PDOStatement->fetch() #1 {main} thrown

The first loop will开发者_Python百科 run (with no problem) but gives an error AFTER the first loop. The error code (line 28) references the line:

while($row = $stmt->fetch()) {

I have never seen this before. As a test, I modified the code to store all returned results as:

$stmt = $db->prepare("SELECT * FROM table");
$stmt->execute();

$rows = $stmt->fetchALL();

foreach($rows as $row) {

    $id = $row['id'];
    $name = $row['name'];

    do something with data returned...


    $id = NULL;
    $name = NULL;

}

and the system works. Any idea as to why?


Note: After looking through 'do something' area again - I realized the database initializers ($sql) were the same in the select and an insert/update statement within the body. Changing these to unique values corrected the issue.

Thanks


Unless this is merely a typo in your question, your arrow operator is incomplete.

$stmt>execute();

// Should be
$stmt->execute();


$stmt>execute();

Shouldn't that be:

$stmt->execute();
0

精彩评论

暂无评论...
验证码 换一张
取 消