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

Господа сори за тупой вопрос, никогда не работал с sql задача: нужно

используя драйвер pg
возвращать из базы юзеров по req.query

куча ифов - некрасиво, как быть?

6 ответов

4 просмотра

А что не так?

select * from user Тип скажи чуть подробнее о задаче. Нужно как-то ограничить? Или помочь с самим подключением и отправкой запроса?

Cloud-Dremin Автор вопроса
Артем
select * from user Тип скажи чуть подробнее о зад...

const { firstName, lastName } = req.query; if (firstName && lastName) { const { rows } = await pg.query('SELECT * FROM users WHERE first_name = $1 AND lastName= $2', [ firstName, lastName, ]); return rows; } if (firstName) { const { rows } = await pg.query('SELECT * FROM users WHERE first_name = $1', [firstName]); return rows; } if (lastName) { const { rows } = await pg.query('SELECT * FROM users WHERE last_name = $1', [lastName]); return rows; } const { rows } = await pg.query('SELECT * FROM users'); return rows; как красиво написать код, чтобы можно было передавать любое количество квери параметров в урле, и это не превращалось в кучу ифов мб есть какой-то прием, или бест практис я просто привык к монге, где я просто фильтр передавал в запрос к базе

Cloud Dremin
const { firstName, lastName } = req.query; ...

ну типа knex что-нибудь заюзать

Cloud Dremin
const { firstName, lastName } = req.query; ...

открой для себя оператор OR в SQL тогда не придется многоэтажные условия писать

Cloud Dremin
const { firstName, lastName } = req.query; ...

Хм, просто динамически строй запрос, в зависимости от входных параметров. (А вообще можно и в запросе "или" писать)

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

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

А еще в перле можно уже @arr1 + @arr2?
Sergei Zhmylove
53
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
Подскажите, где смотреть результат выполнения программы? Код: ;.686 ;Система команд процессора 686 ;.MODEL FLAT,stdcall ;Модель памяти плоская, станда...
Егор Анелькин
5
Привет всем. появился вопрос. Разрабатываю сайт, в данный момент он запущен. Хостинг beget. Добавляю на сайт яндекс метрику с помощью полей client-settings (взято отсюда http...
Andrew
2
;.686 ;Система команд процессора 686 ;.MODEL FLAT,stdcall ;Модель памяти плоская, стандартный ;вызов процедуры ;option casemap:no...
Егор Анелькин
1
почому оно не работает?
Vi Chapmann Chapmann
19
Так а кто может спарсить всех участников чата? Идишники
Magic
18
Есть вопрос: допустим есть железка с каким-то интерфейсом(допустим usb), но как по этому интерфейсу железкой управлять неизвестно, прог нету, а управлять очень хочется надо. К...
Mixail Frolov
15
а как ловят такое ghci> res <- getPos2 urlt 0 (alist !! 0) 200 ghci> res SearchAtom (Search "www.google.com" "/search?q=" "Haskell") "haskell.org" (SearchTS [(2024-05-06 07:...
Fedor
14
короче сгенерила мне эта штука код на ассемблере: struc string val { common local .value dq .value .value: if ~val eq db val end if db 0 } fo...
Vi Chapmann Chapmann
12
Карта сайта