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;
});