Гость
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / Сложное объединение строк полученных по нескольким критериям / 2 сообщений из 2, страница 1 из 1
14.02.2022, 09:12
    #40133892
Bakuard
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Сложное объединение строк полученных по нескольким критериям
Задача: в БД есть некоторая таблица MyTable. Все строки MyTable соответствующие критерию a образуют множество строк A, а все строки соответствующие критерию b образуют множество строк В. Написать запрос, который возвращает объединение множеств A и B, при этом строки выводятся в следующем порядке:
1. Сперва все строки соответствующие только критерию a.
2. Затем все строки соответствующие критерию a и критерию b.
3. Под конец все строки соответствующие только критерию b. Критерии a и b не определенны заранее и формируются динамически.

Что не получается:
1. сперва я подумал объединить два критерия a и b через оператор OR, но возникли проблемы с сортировкой. Я представляю как отсортировать строки по полю или выражению в котором участвуют несколько полей. Но как выразить сортировку по описанному выше критерию - не могу даже представить.
2. пробовал реализовать описанное поведение через три соответствующих запроса. Но такой подход не эффективен, в особенности, если кол-во критериев больше двух.
...
Рейтинг: 0 / 0
14.02.2022, 11:53
    #40133919
court
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Сложное объединение строк полученных по нескольким критериям
Bakuard
Но как выразить сортировку по описанному выше критерию - не могу даже представить.

Код: sql
1.
2.
3.
4.
5.
6.
order by 
  case 
    when "критерию a" and not "критерию b" then 1
    when "критерию a" and "критерию b" then 2
    when not "критерию a" and "критерию b" then 3
  end
...
Рейтинг: 0 / 0
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / Сложное объединение строк полученных по нескольким критериям / 2 сообщений из 2, страница 1 из 1
Целевая тема:
Создать новую тему:
Автор:
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]