Я столкнулся с этой ошибкой при вставке новых данных в базу данныхВнимание: PDOStatement :: Execute(): SQLSTATE [HY093]
Предупреждение: PDOStatement :: Execute(): SQLSTATE [HY093]: Invalid параметр номер: число связанных переменных не соответствует числу маркеров в /opt/lampp/htdocs/projectclasses/DB.php на линии 47
кода методов:
public function query($sql, $params = array())
{
$this->_error = false;
if($this->_query = $this->_pdo->prepare($sql))
{
if(count($params))
{
foreach($params as $param)
{
$x = 1;
$this->_query->bindParam($x, $param);
$x++;
}
}
if($this->_query->execute())
{
$this->_results = $this->_query->fetchAll(PDO::FETCH_OBJ);
$this->_count = $this->_query->rowCount();
}
else
{
$this->_error = true;
}
}
return $this;
}
public function insert($table, $fields = array())
{
if(count($fields))
{
$keys = array_keys($fields);
$values = '';
$x = 1;
foreach($fields as $field)
{
$values .= "?";
if($x < count($fields))
{
$values .= ", ";
}
$x++;
}
$sql = "INSERT INTO users (`". implode('` ,`', $keys) ."`) VALUES (".$values.")";
if(!$this->query($sql, $fields)->error())
{
return true;
}
}
return false;
}
Вставка кода:
$user = DB::getInstance()->insert('users', array(
'username' => 'Marco',
'password' => '123456',
'salt' => 'salt'
));
эхо переменная $ sql, что вы видите? – Clay
Пользователи INSERT INTO ('username',' password', 'salt') VALUES (?,?,?) –