Немного разрабовского треда. Есть движение девов, которые топят, что есть смысл

в более чем 80% случаев отказаться от использования boolean переменных и заменить их на timestamp.
Например вместо
emailVerified
использовать
emailVerifiedAt
, вместо
isDeleted

DeletedAt
.
Преимущества:
Отладка: Для целей отладки может быть полезно знать, когда было изменено булево значение. Например, если в вашем коде есть ошибка, из-за которой булево значение устанавливается неправильно, вы можете использовать временную метку, чтобы отследить, когда произошла ошибка.
Аналитика: она также может быть полезна для аналитических целей. Например, с помощью временной метки можно узнать, сколько пользователей подтвердили свою электронную почту или сколько товаров было удалено за последние 30 дней.
Недостатки:
Сторедж: Хранение булевых значений в виде временных меток занимает больше места в вашей базе данных. Это может быть существенной статьей расходов, если у вас большая база данных.
Усложнение кода: работа с булевыми значениями, хранящимися в виде временных меток, может быть более сложной. Вам придется написать дополнительный код для преобразования временной метки в булево значение.

https://www.youtube.com/watch?v=G5_DLef7_9E

7 ответов

2 просмотра

И чего обсудить хочешь?) я за Boolean ) а timestamp в логи.

Аргумент по большому хранению данных в 2024 году выглядит конечно убедительно 😁😁

Igor- Автор вопроса
Constantine Anikin
Аргумент по большому хранению данных в 2024 году в...

для хранения булевого значения у тебя юзается допустим 2 байта + служебная инфа, а для таймстемпа уже между 7 и 13 байт. Звучит смешно, но берем пару миллионов записей + бекепы это может уже вылиться в гигабайты и лишнее процессорное время на обработку

Igor
для хранения булевого значения у тебя юзается допу...

И выливается это всё в лишние $20 в месяц? 😁

Constantine Anikin
И выливается это всё в лишние $20 в месяц? 😁

так тут речь не про стоимость а про раздутие базы

Это зависит от контекста. Например имея email_verified_at можно будет точно знать когда пользователь получил доступ к аккаунту, и от этого строить свою аналитику, ведь письма не всегда сразу доходят, или, например из-за сбоя встали в долгую очередь. Если ты знаешь что проект на одну страницу и с небольшим интерактивом - то естественно это не нужно, булево будет достаточно.

Похожие вопросы

Обсуждают сегодня

Кто хочет поиграться в легкий взлом специально уязвимого приложения? :) Ваше задани - вы студент группы 416 - оценку в 100 баллов и найти 10 флагов (текстовых) формата Step0...
Andrii Kurdiumov
4
<div class="report-widget"> <h3 style="margin-bottom:10px;"> <?= e(__($this->property('title'))) ?> </h3> <button type="submit" data-request-flash ...
Vladimir 
2
код Event::listen('cms.page.display', function (&$content, $slug, $page, $html) { if (is_object($content)) { dump($content); } else { dump($s...
Point 111
3
Точно проблема в твиге?
Vladimir 
5
Привет Хочу сделать аналог iCloud’а для своих проектов, чтобы пользовательская информация хранилась в облаке, была доступна во всех сервисах, её можно было подсасывать везде)...
Виталий
9
Ребят, а почему вызов add-tag может возвращать не нулевой код даже если операция прошла успешно? Дело в том, что образ корректно помечается, но ветка заходит в "then"... gclou...
Philipp Bondarev
2
<div class="report-widget"> <h3 style="margin-bottom:10px;"> <?= e(__($this->property('title'))) ?> </h3> <button type="submit" data-control="popup...
Point 111
1
@LeMaX10 а ты же делаешь в своем боте капчу на вход в чат? или так же на первое сообщение?
Sergey
4
не хотите в хакеров поиграться? ну только порт надо в оригинальном сообщении спилить
Andrii Kurdiumov
3
Работа нужна кому то?
Мелисса Кондратова
3
Карта сайта