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

У меня есть две таблицы: products(id, name, price) - таблица

продуктов в магазине
tags(id, name) - таблица категории товаров к которым может относится тот или иной продукт

Как можно написать запрос, который найдёт продукты с более чем 10-ю тегами?

У меня вот так получилось
select *
from products p
where (
select count(*)
from product_tag
where p.id = id
) > 10

Но соответственно в связи надо еще промежуточную табличку product_tag или подобная
Где идёт products.id и tags.id

можно ли как-то иначе написать запрос без дополнительной таблицы?

8 ответов

15 просмотров

В приведённой базе вообще не записано, к какой категории относится продукт. Так что вопрос не в запросе -- а в описании базой предметной области. Советую прочитать учебник по реляцыонным базам данных и прорешать из него примеры, перед проектированием баз. Там много нюансов и понятий, которые лучшэ знать.

!rostik- Автор вопроса
Ilya Anfimov
В приведённой базе вообще не записано, к какой кат...

та факт в том что это не я придумал а мне)0)

!rostik
та факт в том что это не я придумал а мне)0)

Тогда посоветуйте тому, кто это придумывает.

select pr.name,count(*) as cnt from products pr join tags on (pr.id=tags.id) group by pr.name having cnt > 10;

Ilya Anfimov
В приведённой базе вообще не записано, к какой кат...

думаю вы неправильно интерпретировали tags.name. имхо, это как раз имя категории, а id - к продукту относится

!rostik- Автор вопроса

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

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

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

Anyone here suffers from unexplained aural migraines, who would be up for talking for a bit? Doesn't *have* to be aural, but I am not asking about headaches, I mean actual mi...
Martin Rys
55
подскажите пожалуйста, как мне освободить результат записанный в переменную result? в чем проблема подскажите если МОЖЕТЕ?
Михаил Helper
28
есть тут кто-то , кто только начал изучать си? если проходите курс на степике или как-то сами изучаете, пишите, может, скооперируемся?..
Eule
25
Слушайте, ещё такая интересная задачка. Сделан аудит действий пользователей через триггеры в базе, соответственно каждый пользователь имеет свой логин и пароль в базе. Это пре...
Сергей Бычков
12
Кстати, раз про скачивание файлов разговор зашел) Сделал бота для себя (транскрибирующего и суммаризирующего встречи) но не ожидал что за 2 месяца 10к пользователей набежит😅...
Andrey Obolenskiy
8
вопрос по москвину - не понимаю вот такого вопроса похоже Сколько разных всегда завершающихся функций с типом a -> a -> b -> a -> a можно реализовать? Две функции одинаково...
Fedor
11
Скажите, тут нет проблемы? IMyInterface1 = interface function GetInterface2: IInterface2; ... function TMyInterface.GetInterface2: IInterface2; begin Result := TI...
Ruslan aka DUDE
18
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
Утра доброго. Просветите пожалуйста. Хочу сделать rest сервер на делфи. Посмотрел 3 фреймворка: dmvc, Mars, mormot. Ни в одном из них не упоминается ассинхронная обработка вхо...
Сергей Бычков
10
Как попросить stack install делать executable без .exe на винде?
Danila Danko
9
Карта сайта