Преобразование типов
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; });