doulianglou0898 2014-04-08 13:38
浏览 43
已采纳

执行()时PHP PDO出错

I am attempting to insert data into database via PDO

Here is my snippet:

try {
        $count = count($db_data);
        for ($i=0; $i < $count ; $i++) { 
            $query_string = "INSERT INTO data (" . $fields[$i] . ") VALUES(" . $values[$i] . ")";
            echo $query_string;
            $vle = $dbh->prepare($query_string);

            $vle->bindValue(':USER', $db_data[$i]['user']);
            $vle->bindValue(':SERVER_NAME', $db_data[$i]['server_name']);
            $vle->bindValue(':SERVER_NAME', $db_data[$i]['description']);
            $vle->bindValue(':PATH', $db_data[$i]['path']);
            $vle->bindValue(':DATE', $db_data[$i]['date']);
            $vle->execute();

            echo "KEY: " . $fields[$i] . "</br>" . "VALUES: " . $values[$i] . "</br>";
        }

    } catch (PDOException $e) {
        echo $e->getMessage();
    }
}

But I am getting following error:

Warning: PDOStatement::execute(): SQLSTATE[HY093]: Invalid parameter number: number of bound variables does not match number of tokens in

EDIT

$query_string is:

INSERT INTO data (user, server_name, description, path, date) VALUES(:jsieclaf, :srvc07.gnotek.com>, :php.nested.base64.526, :a:1:{i:0;s:70:" /home/jsieclaf/public_html/modules/mod_araticl= hess/mod_araticlhess";}, :Mon, 7 Apr 2014 13:48:56 +0300)

$db_data is:

array (size=5)   

'user' => string ':jhjju' (length=9)   
'server_name' => string ':sjvbg07.gnotek.com>' (length=20)   
'description' => string ':php.nested.bade454.526' (length=22)   
'path' => string ':a:1:{i:0;s:70:" /home/jhjju/public_html/modules/mod_araticl=     hess/mod_ereticlhess";}' (length=89)   
'date' => string ':Mon, 7 Apr 2014 13:48:56 +0300' (length=31)
  • 写回答

2条回答 默认 最新

  • duanhanzi8328 2014-04-08 14:14
    关注
    $sql = "INSERT INTO $tableName (" . implode(',', array_keys($assoc_array)) . ") VALUES (" . trim(str_repeat('?,', count($assoc_array)), ',') . ")";
    
    $stm = $dbh->prepare($sql);
    $stm->execute(array_values($assoc_array));
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥20 腾讯企业邮箱邮件可以恢复么
  • ¥15 有人知道怎么将自己的迁移策略布到edgecloudsim上使用吗?
  • ¥15 错误 LNK2001 无法解析的外部符号
  • ¥50 安装pyaudiokits失败
  • ¥15 计组这些题应该咋做呀
  • ¥60 更换迈创SOL6M4AE卡的时候,驱动要重新装才能使用,怎么解决?
  • ¥15 让node服务器有自动加载文件的功能
  • ¥15 jmeter脚本回放有的是对的有的是错的
  • ¥15 r语言蛋白组学相关问题
  • ¥15 Python时间序列如何拟合疏系数模型