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;
});
različica: 4.0