Преобразование типов

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;
});
версия: 4.0