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

Вот у вас есть запрос списка Сущностей с фильтрацией: /entities?fieldA=123 Но у

вас там сложный запрос в БД с JOIN и прочей лабудой. И там на самом деле ни разу не fieldA, а на самом деле там fieldMyBitchA, а к тому же еще и алиас таблицы нужен, то есть реальный фильтр в секции Where должен быть t.fieldMyBitchA.

Вопрос: где вы это делаете? ну то есть на каком этапе у вас fieldA превращается в t.fieldMyBitchA.

Только просьба, не теоритизировать на этот счет, а по факту, кто такое реализовывал, как вы это делали.

9 ответов

5 просмотров
Artur-Karapetov Автор вопроса

вот где я точно не согласен) точно не согласен что это делается на уровне логики

В репе

Artur-Karapetov Автор вопроса
Nikita
В репе

а в логике вы оперируете этими полями?

Artur Karapetov
вот где я точно не согласен) точно не согласен что...

даже если ты сделаешь супер тупые методы в репе даймнеВсехКтоПохожНаПетю даймнеВсехКтоПохожНаВалю ... все равно тебе нужно будет маппить запрос в бд

Artur-Karapetov Автор вопроса

Ну у меня есть просто некая сущность "фильтр", которая выглядит примерно вот так https://github.com/dimuska139/rawg-sdk-go/blob/master/filters.go (это пример не про API, но по смыслу годится). Там есть метод, который заполняет этот фильтр значениями из реквеста (что-то вроде NewFromUrl, например). Этот фильтр я пробрасываю до репозитория, а там делаю if filter.ID != nil {...} и запрос строю через Squirrel. Но явного маппинга полей из URL в названия колонок таблиц я не делаю - только через ifаки всё

Artur-Karapetov Автор вопроса
Dmitriy Sviridov
Ну у меня есть просто некая сущность "фильтр", кот...

ну вот теперь вопрос: у тебя в запросе должно быть красивое ?name=123 а в бд должен улететь where bitch_field_name = 123 на каком этапе name превращается в bitch_field_name ?

Artur Karapetov
ну вот теперь вопрос: у тебя в запросе должно быть...

if filter.Name != nil { qb = qb.Where("user.bitch_field_name = ?", *filter.Name) }

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

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

здравствуйте. совершаю вот такую вещь: strcpy(line, (char)current_number); где current number — неподписанный шорт, line — массив чаров. ругань следующая: main.c:29:30: error...
Roberto's Ширгозиев
13
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
Можно попросить небольшое ревью кода? Тут немнога, я ничего интереснее не придумал, чем написать аналог tree в качестве практики с cmake. https://github.com/hrimov/tree-unix/...
Andrew Hrimov
11
Всем привет. Ребят подскажите пожалуйста. Вопрос по дизасемблировани. Начну с начала. У меня есть скомпилированная программа на ГО (я разработчик) - в ней есть защита лицензии...
Zloy
11
@MrMiscipitlick А можешь макрос написать, который будет вычислять смещение относительно переданных меток? Просто .label1-.label2, и вернуть значение.
КТ315
35
А еще в перле можно уже @arr1 + @arr2?
Sergei Zhmylove
53
кто тебе сказал, что она угроблена? многие только начинают жизнь, после увольнения из Гугла, Майкрософта, Оракла,...
Alex Kom
9
В альтернативе у нас сидеть горбатиться на дядю в галерах, пока не помрешь или пока тебя не заменят более молодым сотрудником, который готов гребсти в два раза дешевле. Вот и ...
Кабан Кабанов
7
все привет. подскажите может кто сталкивался evo 3 если в formlister в параметр formTpl указать имя чанка а не через @CODE то в указанном чанке не парсятся плейсхолдеры [**]? ...
Иван Тарасевич
5
Привет всем. появился вопрос. Разрабатываю сайт, в данный момент он запущен. Хостинг beget. Добавляю на сайт яндекс метрику с помощью полей client-settings (взято отсюда http...
Andrew
2
Карта сайта