Что здесь не так - MySQLi и Custom класс - PullRequest
1 голос
/ 26 апреля 2011

Я делаю собственный класс управления пользователями, который наследуется от класса DBManager.Проблема, которую я имею до сих пор, состоит в выполнении запросов, используя подготовленные операторы mysqli.БД подключается нормально, но затем подготовить оператор не удается.У меня есть объект MySQL в качестве атрибута, который используется в классе.Я новичок в этом mysqli (все время я использовал обычный mysql).Ниже приведен метод конструктора и вставки, который завершается ошибкой.Спасибо за твой хел, и я так долго искал, так что прости меня, если где-нибудь есть что-то подобное.Я не мог найти это.Еще раз спасибо

<?php

protected  $dbLink;
protected  $errorMsg = array();//Inherited by other functions

public function __construct() {
$this->dbLink = new mysqli(DB_HOST, DB_USER, DB_PASS, DB_NAME);
if (mysqli_connect_errno()) {
    $this->addError(mysqli_connect_error());
}
}

public  function insertUsers($arrayofValues) {
        //for inserting users in the database
        $sql = "INSERT INTO users(firstname, lastname, email, username, password) VALUES(?, ?, ?, ?, ?";
        if( $stmt = $this->dbLink->prepare($sql)) {
            $type = array("sssss");
            $params = array_merge($type, $arrayofValues);
            call_user_func_array(array($stmt, 'bind_param'), $this->refValues($params));
            $stmt->execute();

            if($stmt==-1) {
                //query failed
                $this->addError(mysqli_connect_error());
                return false;
            }else {
                return true;
            }
        }
        else{
            $this->addError("Something went wrong before InsertUsers stmt could execute well");
        }
    }
?>

1 Ответ

2 голосов
/ 26 апреля 2011

Закрыть парены в INSERT:

INSERT INTO users(firstname, lastname, email, username, password) VALUES(?, ?, ?, ?, ?)
                                                                                      ^

Обычно это помогает добавить точное описание ошибки в код:

        $this->addError("InsertUsers failed: " . $this->dblink->error);
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...