Преобразование типов
Nette Database автоматически преобразует значения, возвращаемые из базы данных, в соответствующие типы PHP.
Дата и время
Временные данные преобразуются в объекты Nette\Utils\DateTime
. Если вы
хотите, чтобы временные данные преобразовывались в неизменяемые
объекты Nette\Database\DateTime
, установите в конфигурации опцию newDateTime
в
true
.
$row = $database->fetch('SELECT created_at FROM articles');
echo $row->created_at instanceof DateTime; // true
echo $row->created_at->format('j. n. Y');
В случае MySQL тип данных TIME
преобразуется в объекты
DateInterval
.
Логические значения
Логические значения автоматически преобразуются в true
или
false
. В MySQL преобразуется TINYINT(1)
, если мы установим в конфигурации convertBoolean: true
.
$row = $database->fetch('SELECT is_published FROM articles');
echo gettype($row->is_published); // 'boolean'
Числовые значения
Числовые значения преобразуются в int
или float
в
зависимости от типа столбца в базе данных:
$row = $database->fetch('SELECT id, price FROM products');
echo gettype($row->id); // integer
echo gettype($row->price); // float
Пользовательская нормализация
С помощью метода setRowNormalizer(?callable $normalizer)
вы можете установить
собственную функцию для преобразования строк из базы данных. Это
полезно, например, для автоматического преобразования типов данных.
$database->setRowNormalizer(function(array $row, ResultSet $resultSet): array {
// здесь происходит преобразование типов
return $row;
});