Перетворення типів
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;
});