Форум программистов, компьютерный форум, киберфорум
PostgreSQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/5: Рейтинг темы: голосов - 5, средняя оценка - 5.00
14 / 14 / 0
Регистрация: 01.12.2017
Сообщений: 577

Запрос с условием

11.12.2021, 01:20. Показов 952. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый вечер. Нужно сделать такой SELECT запрос, который выберет только активные предложения компании, например, предложение было доступно в январе (January) - значит оно активно. Если предложение было доступно в другие месяцы кроме января - предложение неактивно. У предложения есть менеджер. Таким образом нужно распечатать предложения по месяцам в случаях когда оно активно и неактивно + отсортировать цену (ну это я знаю). Спасибо за помощь или подсказки.
Таблицы выглядят как-то так.

SQL
1
2
3
4
5
6
7
8
9
10
11
12
CREATE TABLE manager
(   id BIGSERIAL PRIMARY KEY,
    first_name VARCHAR(250) NOT NULL,
    second_name VARCHAR(250) NOT NULL);
 
CREATE TABLE proposal
(
    id BIGSERIAL PRIMARY KEY,
    manager_id BIGINT NOT NULL,
    MONTH VARCHAR(20) NOT NULL,
    price NUMERIC NOT NULL,
    FOREIGN KEY (manager_id) REFERENCES manager(id));
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
11.12.2021, 01:20
Ответы с готовыми решениями:

Запрос с условием
Имеется таблица вида: id s_id text 11 1 a 11 2 b 11 3 c 11 4 d 11 5 f 22 1 aa 22 2 bb 22 3 cc

Запрос со сложным условием для одной таблицы
Добрый вечер. Имеется таблица, содержащая следующие поля: пользователь, папка, файл. Соответственно пользователь может создавать разные...

Запрос с условием
Доброго времени суток! Помогите пожалуйста решить одну проблему. Суть в том: Есть таблица сотрудников в которой есть столбик "Член...

3
14 / 14 / 0
Регистрация: 01.12.2017
Сообщений: 577
11.12.2021, 20:31  [ТС]
Активные я выбрал так
SQL
1
2
3
4
5
6
7
8
SELECT * FROM proposal p WHERE
    EXISTS (SELECT * FROM proposal p1 
        WHERE p1.month = 'January' AND p.manager_id = p1.manager_id) 
        ORDER BY CASE MONTH 
        WHEN 'December' THEN 1 
        WHEN 'January' THEN 2 
        WHEN 'February' THEN 3 END, 
        price DESC
А вот как выбрать неактивные - не приложу ума. Пробую так, в принципе почти правильно, но выбирает все предложения, которые "не январские", но нужны только те предложения, которые в январе не реализовывались менеджерами в принципе.

SQL
1
2
3
4
5
6
7
8
SELECT * FROM proposal p WHERE
    EXISTS (SELECT * FROM proposal p1 WHERE
        ((p1.month = 'December' OR p1.month = 'February') AND p.month != 'January') AND p.manager_id = p1.manager_id)
        ORDER BY CASE MONTH 
        WHEN 'December' THEN 1 
        WHEN 'January' THEN 2 
        WHEN 'February' THEN 3 END, 
        price DESC
0
 Аватар для Аватар
5393 / 1465 / 513
Регистрация: 31.05.2012
Сообщений: 5,153
11.12.2021, 21:55
Лучший ответ Сообщение было отмечено Teylor как решение

Решение

а в первом запросе просто not добавить: not exists ?
1
14 / 14 / 0
Регистрация: 01.12.2017
Сообщений: 577
11.12.2021, 22:34  [ТС]
Аватар, и на это ушло полдня
СПАСИБО!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
11.12.2021, 22:34
Помогаю со студенческими работами здесь

Запрос с условием
Всем, привет! Если не сложно то помогите составить запрос. Т.к. SQL знаю совсем чуть чуть, то очень надеюсь на вашу помощь. Суть в...

Запрос с условием
Всем привет. Такая проблема. У меня есть таблица, состоящая из полей: Авторы, Название, Описание, Год выхода. Мне нужно написать селект,...

Запрос с условием
Ситуация такая: есть таблица Студенты(Фамилия, пол, дата рожд), надо сделать запрос чтобы выводилось общее количество студентов по...

Запрос с условием
Как записать условие в запросе для следующей задачи: рассчитать скидку. Скидка предоставляется абонентам, имеющим телефон более 10 лет, в...

Запрос с условием
Подскажите пожалуйста, как сделать запрос с условием, в котором отобразилась бы определённая должность и возраст менее 40 лет? То есть...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Functional First Web Framework Suave
DevAlt 30.03.2026
Sauve. IO Апнулись до NET10. Из зависимостей один пакет, работает одинаково хорошо как в режиме проекта так и в интерактивном режиме. из сложностей - чисто функциональный подход. Решил. . .
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru