Перетворення типів
Nette Database автоматично перетворює значення, отримані з бази даних, у відповідні типи PHP.
Дата і час
Значення дати і часу конвертуються в об'єкти Nette\Utils\DateTime
. Якщо
ви бажаєте, щоб значення дати і часу перетворювалися на незмінні
об'єкти Nette\Database\DateTime
, увімкніть опцію newDateTime
у конфігурації.
$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
.
$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); // ціле число
echo gettype($row->price); // поплавок
Користувацька нормалізація
Ви можете визначити користувацьку функцію для перетворення рядків
бази даних за допомогою методу setRowNormalizer(?callable $normalizer)
. Це
корисно, наприклад, для автоматичного перетворення типів даних.
$database->setRowNormalizer(function(array $row, ResultSet $resultSet): array {
// перетворення типів даних відбувається тут
return $row;
});