Pretvorba tipov
Nette Database samodejno pretvarja vrednosti, vrnjene iz baze podatkov, v ustrezne PHP tipe.
Datum in čas
Časovni podatki se pretvorijo v objekte Nette\Utils\DateTime
. Če želite, da se časovni podatki pretvorijo
v nespremenljive objekte Nette\Database\DateTime
, nastavite v konfiguraciji možnost 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');
V primeru MySQL pretvarja podatkovni tip TIME
v objekte DateInterval
.
Booleove vrednosti
Booleove vrednosti se samodejno pretvorijo v true
ali false
. Pri MySQL se pretvarja
TINYINT(1)
, če nastavimo v konfiguraciji
convertBoolean
.
$row = $database->fetch('SELECT is_published FROM articles');
echo gettype($row->is_published); // 'boolean'
Številske vrednosti
Številske vrednosti se pretvorijo v int
ali float
glede na tip stolpca v bazi podatkov:
$row = $database->fetch('SELECT id, price FROM products');
echo gettype($row->id); // integer
echo gettype($row->price); // float
Lastna normalizacija
Z metodo setRowNormalizer(?callable $normalizer)
lahko nastavite lastno funkcijo za transformacijo vrstic iz baze
podatkov. To je koristno na primer za samodejno pretvorbo podatkovnih tipov.
$database->setRowNormalizer(function(array $row, ResultSet $resultSet): array {
// tukaj poteka pretvorba tipov
return $row;
});