MySQLi получает ошибку запроса

Когда я выполняю sql-запросы для моего php-приложения с использованием MySQLi, ошибки всегда пустые или нулевые, поэтому я не могу их регистрировать или распечатывать, что довольно неприятно... У меня не возникало проблем со вставкой, обновлением или удалением данных с помощью фрагмента ниже, когда ожидается, что запрос не вызовет ошибку.

Я использую PHP 5.3.9 в версии сообщества Zend Server 5.6.0 и mysqli mysqlnd 5.0.8-dev - 20102224 - $Revision: 318113 $

Это код, который выполняет мои запросы:

...
$this->last= $this->mysqli->query($sql);
if (!$this->last) 
{
    print_r($this->mysqli);

    var_dump($this->mysqli->error);
    var_dump($this->mysqli->errno);
    var_dump($this->mysqli);
    $msg = 'Query failed [ ' . $this->mysqli->error . ' ]';

    $this->mysqli->rollback();
    throw new Exception($msg, ...);
}
...

В целях тестирования я ввел город с именем "bob" в свою базу данных и попытался вставить другой город с тем же именем, и вот что было напечатано:

mysqli Object
(
    ...
    [errno] => 1062
    [error] => Duplicate entry 'bob' for key 'unq_city'
    ...
)
string(0) ""
int(0)
object(mysqli)#6 (18) {
  ...
  ["errno"]=>
  int(0)
  ["error"]=>
  string(0) ""
  ...
}

Здесь использование var_dump или доступ к errno или ошибке моего объекта mysqli, как я уже говорил ранее, является нулевым. ОДНАКО print_r показывает ожидаемую ошибку! Что я здесь не так делаю? Я никогда не использовал mysqli раньше и перехожу с oci8, поэтому я надеюсь, что это всего лишь глупая ошибка.


Редактировать:

Я тестировал свое приложение на более старом сервере, PHP 5.3.8, ZSCE 5.5.0 и mysqlnd 5.0.8-dev - 20102224 - $Revision: 310735 $ с идентичной конфигурацией из того, что я могу сказать. Все дампы и распечатки показывали все данные mysqli без каких-либо пустых полей!

1 ответ

Можете ли вы поставить вывод этого?

$tmp = array();
foreach($this->mysqli as $key => $value)
    $tmp[$key] = $value;
print_r($tmp);
Другие вопросы по тегам