2014-04-08 102 views
-3

我試圖通過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) 
+0

什麼呢回聲$ QUERY_STRING; ? –

+0

簡單的調試是爲了......請發佈'print_r($ db_data)',這樣我們就可以看到你開始使用什麼,'echo $ query_string;'看看它產生了什麼聲明。 –

+0

PDO的全部重點是編寫語句,但是您仍然要連接SQL字符串 – meda

回答

1
$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)); 
+0

謝謝@Sid Hussain!當我的var_dump我的$ assoc_array: '陣列(尺寸= 5) 0 =>字符串 'jsiespaf'(長度= 8) 1 =>字符串 'srvc07.gnotek.com>'(長度= 19) 2 = > string'php.nested.base64.526'(length = 21) 3 => string'a:1:{i:0; s:70:「/ home/jsieclaf/public_html/modules/mod_araticl = hess/mod_araticlhess「;}'(length = 88) 4 => string'2014年4月7日星期一13:48:56 +0300'(長度= 30)' 我上面有這個。 我的問題是我該如何運用你的陳述。聲明: 'trim(str_repeat('?,',count($ assoc_array)),',')。 「)」;' – curiozity

+0

curiozity,array_keys會給你數組鍵,使用implode,所有的鍵都使用「,」連接在一起,然後下一部分處理佔位符,「?」在這種情況下可以用作佔位符,你需要知道有多少「?」使用,這就是使用str_repeat的地方,使用數組元素的數量。最後最後的「,」被刪除。在這種情況下,您不需要使用bindValue,因爲您沒有綁定名稱/值參數。我給出的陳述,你不需要for循環,只需把你的try/catch中給出的陳述。 –

-1
 
try { 
    $sql = "INSERT INTO $tableName (" . implode(',', array_keys($assoc_array)) . ") VALUES (" . trim(str_repeat('?,', count($assoc_array)), ',') . ")"; 
    $stm = $db->prepare($sql); 
    $stm->execute(array_values($assoc_array)); 

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

你的兩個答案中的哪一個實際上是答案? – tadman

+0

上面的代碼被重構,顯示出,你不需要你在try/catch之前擁有的東西。這是我的實際答案。 –