Я столкнулся с проблемой. Моя инфраструктура отлично работала с PHP 5.3.0. Я обновил мою версию PHP до PHP 5.4.x, и у меня появилось несколько проблем с некоторыми частями моей инфраструктуры.
После обновления версии PHP PDO lastInsterId()
всегда возвращает 0
.
У меня есть поле автоинкремента, называемое id
.
Он без проблем добавляет данные в базу данных.
По какой-то причине я продолжаю получать 0 как последний идентификатор вставки.
Вот мой код;
databaseobjects.php
public static function create () {
global $db;
$attributes = self::sanitize(static::$fields);
$sql = "INSERT INTO ".PREFIX.static::$table_name." (";
$sql .= join(", ", array_keys($attributes));
$sql .= ") VALUE (:";
$sql .= join(", :", array_keys($attributes));
$sql .= ")";
return ($db->crudQuery($sql, $attributes)) ? true : false;
}
public static function lastInsertID () {
global $db;
return $db->handler->lastInsertId();
}
database.php
public function crudQuery($sql, $data) {
$sth = $this->handler->prepare($sql);
return $sth->execute($data);
}
Сначала вызывается метод create()
, затем вызывается метод crudQuery()
.
Как я уже упоминал ранее, я могу успешно добавить данные в базу данных MySQL.
К сожалению, когда я вызываю метод lastInsterID()
, он всегда возвращает 0.
Я буду очень рад, если вы сможете помочь мне с этой проблемой, прежде чем я получу последний ID с SQL Query (: