Перетворення типів

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