我試圖通過PDOPHP PDO給執行時()
這裏將數據插入到數據庫中的錯誤是我的片斷:
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();
}
}
但我得到以下錯誤:
警告:PDOStatement :: execute():SQLSTATE [HY093]:無效的參數編號:綁定變量的數量與令牌的數量不匹配
編輯
$query_string
是:
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是:
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)
什麼呢回聲$ QUERY_STRING; ? –
簡單的調試是爲了......請發佈'print_r($ db_data)',這樣我們就可以看到你開始使用什麼,'echo $ query_string;'看看它產生了什麼聲明。 –
PDO的全部重點是編寫語句,但是您仍然要連接SQL字符串 – meda