2017-04-25 91 views
-1

我試圖讓我的CMS能夠編輯不同的字段(例如名稱)。當我點擊「更新」,不過,我得到以下錯誤:更新數據庫時出現「無效參數號」,爲什麼?

Fatal error: Uncaught exception 'PDOException' with message 'SQLSTATE[HY093]: Invalid parameter number: number of bound variables does not match number of tokens' in /studenthome.hallam.shu.ac.uk/STUDENTHOME10/1/b5035381/public_html/affinity/cms/process/editRecord.php: in /studenthome.hallam.shu.ac.uk/STUDENTHOME10/1/b5035381/public_html/affinity/cms/process/editRecord.php on line 28 PDOException: SQLSTATE[HY093]: Invalid parameter number: number of bound variables does not match number of tokens in /studenthome.hallam.shu.ac.uk/STUDENTHOME10/1/b5035381/public_html/affinity/cms/process/editRecord.php on line 28 Call Stack: 0.0029 659144 1. {main}() /studenthome.hallam.shu.ac.uk/STUDENTHOME10/1/b5035381/public_html/affinity/cms/process/editRecord.php:0 0.0135 672928 2. PDOStatement->execute() /studenthome.hallam.shu.ac.uk/STUDENTHOME10/1/b5035381/public_html/affinity/cms/process/editRecord.php:28

這裏是我的代碼:

<?php 
ini_set('display_errors', 1); 

// add your includes for connections and functions 
// make sure the path is correct 
require ('../../includes/conn.inc.php'); 
require ('../../includes/functions.inc.php'); 

// sanitize user variables 
$splayerName = safeString($_POST['playerName']); 
$splayerDescription = safeString($_POST['playerDescription']); 
$splayerImage = safeString($_POST['playerImage']); 
$splayerRank = safeString($_POST['playerRank']); 
$splayerSpec = safeString($_POST['playerSpec']); 
$splayerID = safeInt($_POST['playerID']); 

// build prepare statement 
$sql = "UPDATE affinity SET playerName = :playerName, 
playerDescription = :playerDescription, 
playerImage = :playerImage, 
playerRank = :playerRank, 
playerSpec = :playerSpec 
WHERE playerID = :playerID"; 
$stmt = $pdo->prepare($sql); 

$stmt->bindParam(':playerName', $splayerName, PDO::PARAM_STR); 
$stmt->bindParam(':playerDescription', $splayerDescription, PDO::PARAM_STR); 
$stmt->bindParam(':playerImage', $splayerImage, PDO::PARAM_STR); 
$stmt->bindParam(':playerRank', $splayerRank, PDO::PARAM_STR); 
$stmt->bindParam(':playerRank', $splayerRank, PDO::PARAM_STR); 
$stmt->bindParam(':playerSpec', $splayerSpec, PDO::PARAM_INT); 
$stmt->execute(); 

// redirect browser 
header("Location: ../cms.php"); 

// make sure no other code executed 
exit; 
?> 

我不知道爲什麼,這是行不通的;我該如何解決它?

+1

你綁定5個變量,但使用6個字段。你有兩倍的排名 – RST

+0

你不知道什麼是錯的,因爲你不檢查代碼中的錯誤。永遠不要假設代碼總是完美無缺地工作。 –

回答

0

你的playerID綁定在哪裏?這是造成它的原因。你有兩次綁定秩序和ID從未,他們應該是正確的?

$stmt->bindParam(':playerName', $splayerName, PDO::PARAM_STR); 
$stmt->bindParam(':playerDescription', $splayerDescription, PDO::PARAM_STR); 
$stmt->bindParam(':playerImage', $splayerImage, PDO::PARAM_STR); 
$stmt->bindParam(':playerRank', $splayerRank, PDO::PARAM_STR); 
$stmt->bindParam(':playerSpec', $splayerSpec, PDO::PARAM_INT); 
$stmt->bindParam(':playerID', $splayerID, PDO::PARAM_STR); 
+0

你的權利感謝指出 – unreal1357

0
<?php 
ini_set('display_errors', 1); 

// add your includes for connections and functions 
// make sure the path is correct 

require ('../../includes/conn.inc.php'); 

require ('../../includes/functions.inc.php'); 

// sanitize user variables 

$splayerName = safeString($_POST['playerName']); 
$splayerDescription = safeString($_POST['playerDescription']); 
$splayerImage = safeString($_POST['playerImage']); 
$splayerRank = safeString($_POST['playerRank']); 
$splayerSpec = safeString($_POST['playerSpec']); 
$splayerID = safeInt($_POST['playerID']); 

// build prepare statement 

$sql = "UPDATE affinity SET playerName = :playerName, 
playerDescription = :playerDescription, 
playerImage = :playerImage, 
playerRank = :playerRank, 
playerSpec = :playerSpec 
WHERE playerID = :playerID"; 
$stmt = $pdo->prepare($sql); 
$stmt->bindParam(':playerName', $splayerName, PDO::PARAM_STR); 
$stmt->bindParam(':playerDescription', $splayerDescription, PDO::PARAM_STR); 
$stmt->bindParam(':playerImage', $splayerImage, PDO::PARAM_STR); 
$stmt->bindParam(':playerRank', $splayerRank, PDO::PARAM_STR); 
$stmt->bindParam(':playerSpec', $splayerSpec, PDO::PARAM_STR); 
$stmt->bindParam(':playerID', $splayerID, PDO::PARAM_INT); 
$stmt->execute(); 

// redirect browser 

header("Location: ../cms.php"); 

// make sure no other code executed 

exit; 
?> 
1

:playerRank

已經綁定的2倍和

:playerID

尚未綁定。

和:

:playerSpec

應該綁定爲一個字符串,而不是一個int。

$stmt->bindParam(':playerName', $splayerName, PDO::PARAM_STR); 
$stmt->bindParam(':playerDescription', $splayerDescription, PDO::PARAM_STR); 
$stmt->bindParam(':playerImage', $splayerImage, PDO::PARAM_STR); 
$stmt->bindParam(':playerRank', $splayerRank, PDO::PARAM_STR); 
$stmt->bindParam(':playerSpec', $splayerSpec, PDO::PARAM_STR); 
$stmt->bindParam(':playerID', $splayerID, PDO::PARAM_INT); 
相關問題