0
我試圖從我的數據庫執行SELECT
,但出現錯誤,我不明白爲什麼。我只能說,這似乎是在prepare()
聲明失敗。任何幫助,將不勝感激。錯誤「檢查與您的MySQL服務器版本對應的正確語法以使用附近的手冊」
$sQuery = "SELECT * FROM ? WHERE `email` = ? AND `password` = ?";
$sTypes = "sss";
$aParams = array("user", "[email protected]", "password");
以上是查詢和bind_param值。
function conn($sQuery, $sTypes=null, $aParams=null){
$sMessage = '';
$db = new mysqli('localhost','root','','myvyn') or die('unable to connect!');
if($db->connect_errno){
$message = $db->connect_error;
} else{
$stmt = $db->stmt_init();
if (!($stmt->prepare($sQuery))) {
var_dump("Prepare failed: (" . $stmt->errno . ") " . $stmt->error);
}
if($sTypes&&$aParams){
$bindParams[] = $sTypes;
foreach($aParams as $param){
$bindParams[] = $param;
}
call_user_func_array(array($stmt, 'bind_param'), $bindParams);
}
$stmt->execute();
$oResult = $stmt->get_result();
while($rows = $oResult->fetch_assoc()){
$aRows[] = $rows;
}
$oResult->free();
$db->close();
return $aRows;
}
}
如果它來自用戶輸入,應該在注入查詢之前檢查白名單中的$ tblName。 – halfer 2015-02-06 01:33:05