Konwersja typów

Nette Database automatycznie konwertuje wartości zwrócone z bazy danych na odpowiednie typy PHP.

Data i czas

Dane czasowe są konwertowane na obiekty Nette\Utils\DateTime. Jeśli chcesz, aby dane czasowe były konwertowane na niemutowalne obiekty Nette\Database\DateTime, ustaw w konfiguracji opcję newDateTime na true.

$row = $database->fetch('SELECT created_at FROM articles');
echo $row->created_at instanceof DateTime; // true
echo $row->created_at->format('j. n. Y');

W przypadku MySQL konwertuje typ danych TIME na obiekty DateInterval.

Wartości logiczne

Wartości logiczne są automatycznie konwertowane na true lub false. W MySQL konwertuje się TINYINT(1), jeśli ustawimy w konfiguracji convertBoolean.

$row = $database->fetch('SELECT is_published FROM articles');
echo gettype($row->is_published); // 'boolean'

Wartości liczbowe

Wartości liczbowe są konwertowane na int lub float w zależności od typu kolumny w bazie danych:

$row = $database->fetch('SELECT id, price FROM products');
echo gettype($row->id);    // integer
echo gettype($row->price); // float

Własna normalizacja

Za pomocą metody setRowNormalizer(?callable $normalizer) możesz ustawić własną funkcję do transformacji wierszy z bazy danych. Jest to przydatne na przykład do automatycznej konwersji typów danych.

$database->setRowNormalizer(function(array $row, ResultSet $resultSet): array {
	// tutaj następuje konwersja typów
	return $row;
});
wersja: 4.0