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

Есть таблица с продуктами, их там условно 100 штук Есть таблица

с заказами, их там на порядок больше, чем самих продуктов
Есть пользователи, их человек 10

Я хочу получить товары, которые покупал пользователь под номером 1.

Если я делаю запрос
select products.id, products.name from products join orders on orders.product_id=products.id and orders.user_id=1

Я получаю товары но с дублями, так как один товар заказывали по несколько раз. В этом случае нам приходится читать все заказы пользователя по указанным товарам.

Если я делаю запрос с distinct, то всё верно, получаем уникальные товары купленные пользователем:
select distinct on (products.id) products.id, products.name from products join orders on orders.product_id=products.id and orders.user_id=1

Но вопрос, база читает из таблицы заказов по одному заказу к каждой паре товар-пользователь, или так же все заказы как в первом запрос и только потом отфильтровывает через distinct?

1 ответов

7 просмотров

Постройте план и увидите. Да, если id - первичный ключ в products, то можете просто сделать group by products.id вместо distinct

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

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

читать файл максимально быстро? странный вопрос))
zamtmn
52
всем привет! углубившись в плюсы и начав изучать реверсинг понял, что без асм'а никуда со своими высокоабстрактными представлениями начал изучать механизмы асма, и не совсем п...
9
Привет. Сразу скажу, что на C/C++/Rust я не пишу, но тем не менее возникла потребность дебага C/C++/Rust кода. Суть: есть серверное приложение, которое периодически ведёт себ...
ninekeem 🐳
4
буквально один оставшийся вопрос при выполнении строчки mov eax, 5 операнд "5" будет присутствовать где-либо в памяти (любой), кроме как в памяти блока .code? подвопрос: как...
12
Всем ку. Подскажите, если задекларировал массив так: int arr[10] = {1, 2, 3, 4}, то в arr[4] будет мусор или нуль?
Sasha K
14
я не понимаю mov [r11+8],rcx и прочие. мы записываем значение из rcx, куда?
Bor
15
а зачем этот вопрос для удаления из чата?
Mёdkinson Medvezhkin
63
у меня такой вопрос про память в x86 возник, может кто пояснить?.. у процессора есть (как минимум) 3 типа адресов (названия "п1", "п2", "п3" --- мои, чтобы проще было дальше)...
Toideng
5
А какие расширения активно используются в промышленности? Именно идейные, по типу гадт, а не всякие оверлоадедстрингс
Степан
11
у процессора есть (как минимум) 3 типа адресов (названия "п1", "п2", "п3" --- мои, чтобы проще было дальше): - "п1" --- виртуальный адрес, то есть тот, который ресолвится в "п...
Toideng
3
Карта сайта