170 похожих чатов

Кто-Нибудь тестирует время? И отсюда вопрос (продублирую): когда вы делаете

soft delete, где вы поля is_deleted и deleted_at обновляете? В репе или бизнесухе?

Это похоже на деталь хранения, но тогда какая-то каша: почему все поголовно created_at и updated_at в бизнес-логике обновляют? Есть какой-то подход, которого стоит придерживаться?

14 ответов

19 просмотров

в бизнес логике так соблюдается правило, что репозиторий не модифицирует данные + проще тестировать

Я бы is_deleted обновлял в слое репозитория. Потому что это относится к особенностям хранения данных в хранилище. А вот время удаления я бы передавал из бизнес-логики. Потому что теоретически может быть какая-то необходимость удалять задним числом, например

Если поля используются в бизнес-логике, то обновляются в бизнес-логике. Если исключительно на уровне БД, то на уровне бизнес-логики они вообще не должны существовать

Вообще в бизнес слое, т.к. репа не должна знать ничего практически (могут возникнуть проблемы когда понадобится изменить поня в бизнес слое, но будут конфликты из-за того что в репе логика меняется). Но кажется что все больше я не навижу софтделиты и хочу их поменять на какую-нибудь archived_at т.к. не всегда понятно обновлять ли удаленные данные или нет, с архивными по проще

А4 Одноногое- Автор вопроса

А как архивные данные принципиально отличаются от помеченных как is_deleted? Все равно ведь где-то нужна будет проверка, что их нельзя обновлять Или это просто название более передающее суть?

А4 Одноногое
А как архивные данные принципиально отличаются от ...

возможно это просто проблема в том что большинство ОРМ (с которыми я в последнее время чаще работаю) запищивают глобальное поведение на софтделиты и просто исключают их из всех выборок с архивными ты можешь не держать это условие постоянно в голове (хотя тебе везде надо учитывать что есть архивные записи)

А4 Одноногое- Автор вопроса
Александр Костюченко
в бизнес логике так соблюдается правило, что репо...

Если мы все поля модифицируем в бизнес-логике, то по идее можно избавиться от метода repo.DeleteItem, оставив только repo.UpdateItem

А4 Одноногое
Если мы все поля модифицируем в бизнес-логике, то ...

лучше отдельный метод всё же, т.к в системах побольше удаление это не просто обновления одного поля в 1 таблице, а больше действий)

я имею ввиду, что при update вы меняете одну таблицу обычно, просто полей список может отличаться а при delete может быть софт удаление не только сущности но и связанных например или запись в лог

в репе транзакцией вероятно) но в реале где-нибудь в сервисе транзакцию открывают местами или в контексте кидают и тд делайте лишь бы протестировать можно было

А4 Одноногое- Автор вопроса

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

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

Если у меня есть такой класс: Object = {} function Object:new(a_name, a_transform, a_color, a_mesh, a_material, a_shader, a_textures) local private = {} private.n...
Cuarno Vile
4
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
зачем же переименовывать ? чтобы кол-во участников возросло или вдруг IBM от этого снова на свифте начнет кодить ? Я не понимаю что страшного в том что свифт гавно, если это т...
Oleh Nerzh
10
здравствуйте. совершаю вот такую вещь: strcpy(line, (char)current_number); где current number — неподписанный шорт, line — массив чаров. ругань следующая: main.c:29:30: error...
Roberto's Ширгозиев
13
@MrMiscipitlick А можешь макрос написать, который будет вычислять смещение относительно переданных меток? Просто .label1-.label2, и вернуть значение.
КТ315
35
А еще в перле можно уже @arr1 + @arr2?
Sergei Zhmylove
53
Добрый день! Подскажите, пожалуйста: какими компетенциями нужно обладать, чтобы претендовать на работу эрланг (отдельная благодарность, если про элексир тоже подскажете) разр...
via ☸️ led
20
Всем привет. Ребят подскажите пожалуйста. Вопрос по дизасемблировани. Начну с начала. У меня есть скомпилированная программа на ГО (я разработчик) - в ней есть защита лицензии...
Zloy
11
Можно попросить небольшое ревью кода? Тут немнога, я ничего интереснее не придумал, чем написать аналог tree в качестве практики с cmake. https://github.com/hrimov/tree-unix/...
Andrew Hrimov
11
Привет всем. появился вопрос. Разрабатываю сайт, в данный момент он запущен. Хостинг beget. Добавляю на сайт яндекс метрику с помощью полей client-settings (взято отсюда http...
Andrew
2
Карта сайта