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

Ребята а есть ли смысл выносить поле из таблицы в

другую таблицу которое в большинстве случает имеет null но нужно при каждом запросе? Допустим тот же soft delete мы можем создать поле deleted_at и deleted_by в таблице а можем вынести в отдельную таблицу эти поля, но если мы выносим нам все равно придется каждый раз джойнить и проверять в каких строках null что бы показывать только живые

2 ответов

9 просмотров

зависит от запросов. можно оставить, а для поиска создать ON (deleted_at) WHERE deleted_at IS NOT NULL индекс такие индексы исользуются базой даже без явного указания предиката в `WHERE`-части запроса

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

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

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

Вопрос по диагностике ошибок (я знаю в чем, в данном конкретном примере, я знаю, как исправить, пример модельный, понятно, что в реальности бывает намного запутаннее). module...
ⰄⰎⰋⰐⰐⰑⰛⰤⰧⰧⰩⰄ ⰊⰑⰁⰓⰡⰛⰦⰕⰫ
10
А дальше что?.. Записать в файл, потом в Код?.. И потом разбирать как-то?..
Хаскель Моисеевич Гопник
14
А чем вам питонисты не угодили?😂
.
79
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
48
type TObj = object procedure Init; virtual; end; TObj1 = object(TObj) procedure Init; override; end; procedure TObj1.Init; begin inherited; end; procedur...
Alexander 👋
29
@y0zhig @shizzard А можно я опишу цель и может вообще ерланг мне не подходит. На текущий момент как я понимаю у ерланга есть легковесные потоки и задача выполняется в каком т...
Дмитрий Спиридонов
5
Есть предложения, как подобное можно упростить?
Hemul GM
12
У меня вопросик назрел. Почему, создав класс без наследования и реализации деструктора Destroy, деструктор не вызывался при free. Потом указал наследование от tobject и overri...
Сергей Бычков
9
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
86
Такой вопросец - есть функция function MySuperDuperConcat(const a: array of AnsiString): AnsiString; Как мне в её теле сделать вот так? Result:=Concat(a); А не грустный вариан...
notme
15
Карта сайта