DO SQL ERROR: SQLSTATE[HY093]: Invalid parameter number: number of bound variables does not match number of tokens
Что означает знаю.
Но когда я вручную подставляю данные они проходят, а когда через переменую то нет
$link = PDO_DataBase::getInstance()->getConnection();
$new_max_win = 2;
$lot_id = 5;
$param = null;
$n = null;
for ($f=0; $f < $new_max_win; $f++) {
$cods = generate_string(10);
$n .= "(?,?),";
$cols = substr($n, 0, -1);
$param .= "'$lot_id','$cods',";
$arr_cods = substr($param, 0, -1);
}
echo $arr_cods ;
$sql = "INSERT INTO promo_cods (lot_id,code) VALUES $cols";
$params = array( 5,'s1m3c1m4x1',5,'n5f1l5g2z3');
$result = singleUpdate($link,$sql,$params);
$params = array( 5,'s1m3c1m4x1',5,'n5f1l5g2z3');//Вот так работает.
$arr_cods = '5','s1m3c1m4x1','5','n5f1l5g2z3';//А вот так нет
$params = array($arr_cods);
function singleUpdate($conObject,$sql,$params){
if(!is_array($params)){
$params = array($params);
}
try{
$process = $conObject->prepare($sql);
$process->execute($params);
if($process->rowCount() == 0){
$data = array('info' => 'SQL return 0 row');
}else{
$data = array('success' => 'Success Update');
}
}catch(PDOException $e){
die("PDO SQL ERROR: " . $e->getMessage() . "<br/>");
}
$process->closeCursor();
return $data;
}