PostgreSQL. Запросы к БД на примере сайта объявлений

Добавлено: 03/12/2021 15:59 |  Обновлено: 03/12/2021 16:01 |  Добавил: nick |  Просмотры: 2053 Комментарии: 0
Вводная часть
Выкладываю примеры sql-запросов из одного тестового задания. В качестве СУБД используется PostgreSQL. БД создана для воображаемого сайта объявлений.
Есть схема базы данных для сайта объявлений, похожего на Avito, со следующими сущностями: 1) пользователи (users):
  • регистрируются на сайте,
  • публикуют объявления (у одного пользователя может быть много или ни одного объявления),
  • комментируют объявления других пользователей;
2) категории (categories):
  • типы, по которым группируются объявления;
3) объявления (offers),
  • относятся к одной или больше категорий;
  • тип объявления (offer_type) может быть либо ‘buy’ (Куплю), либо ‘sell’ (Продам);
4) комментарии (comments):
  • одноуровневые, т.е. пользователи не могут комментировать комментарии других пользователей.

Примеры запросов к БД

1. Выберите список всех комментариев, созданных пользователем с идентификатором 1. Поля для вывода: id, created_at, offer_id, comment_text.
select c.id, c.created_at, c.offer_id, c.comment_text
from comments c
inner join users u on c.user_id=u.id
where u.id = 1;
2. Выведите список объявлений (id, created_at, user_id, offer_type, title, price, picture), опубликованных в октябре 2021 года с сортировкой по дате публикации от самых свежих к более поздним. Дату публикации выведите в формате ‘DD.MM.YYYY’.
select o.id, to_char(o.created_at::date, 'dd.mm.yyyy'), o.user_id, o.offer_type, o.title, o.price, o.picture
from offers o
where o.created_at::text like '2021-10-%'
order by o.created_at desc;
3. Выберите список пользователей, которые ещё не опубликовали ни одного объявления. Поля для вывода: идентификатор пользователя, email, дата регистрации, имя и фамилия одной строкой как ‘user_name’. Отсортируйте по возрастанию даты регистрации.
select concat_ws(' ', u.id, u.email, u.created_at, u.first_name, u.last_name) as user_name
from users u
left join offers o
on o.user_id = u.id
where o.user_id is null
order by u.created_at;
4. Выберите среди всех объявлений на продажу самые дорогие товары, их количество динамическое и заранее неизвестно. Выведите их идентификаторы, автора (имя, фамилия), заголовки и цену продажи.
select o.id, o.title, o.price, u.first_name, u.last_name
from offers o, users u
where u.id = o.user_id and price = (select max(price) from offers);
5. Для вывода на сайте выберите список всех категорий, в которых есть хотя бы одно объявление с указанием количества объявлений по каждой категории. Выведите id категории, title, slug, количество объявлений (offer_amount).
select ca.id, ca.title, ca.slug, count(o.id) as offer_amount
from categoryoffer co 
join offers o on co.offer_id = o.id 
join categories ca on co.category_id = ca.id 
group by (ca.id);

Оставьте свой комментарий

Комментариев нет