Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.71/7: Рейтинг темы: голосов - 7, средняя оценка - 4.71
 Аватар для Toros1992
899 / 554 / 275
Регистрация: 26.11.2015
Сообщений: 1,758
Записей в блоге: 2

Исключение. Есть ли способ лучше?

12.11.2019, 12:23. Показов 1394. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет. Есть такой запрос:
T-SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
SELECT 
    t.Name
FROM (
    SELECT Distinct
        c.Name, c.ID
    FROM Customer C 
    JOIN Order O on C.ID = O.Customer_ID
    WHERE O.Product_ID = 1
) t
LEFT JOIN (
    SELECT Distinct
        c.ID
    FROM Customer C 
    JOIN Order O on C.ID = O.Customer_ID
    WHERE O.Product_ID = 2
) ex on t.ID = ex.ID
WHERE ex.ID is NULL
Его идея - получить всех клиентов, заказывавших когда либо один товар, но не заказывавших ни разу другой товар.
Подскажите пожалуйста, есть ли способ написать его более эффективно? Я додумался только до двух временных таблиц с результатами вложенных запросов
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
12.11.2019, 12:23
Ответы с готовыми решениями:

Проект .adp: получить ОДНО значение с свервера - какие способы есть, какой способ лучше?
Дано: 1) проект .adp, подключенный к базе даных на сервере MS SQL Server. 2) текст запроса, выбирающий ровно одно значение (одно поле,...

Какой способ лучше
Производятся вычисления в цикле, где в зависимости от условий подключаются или не подключаются через include разные самописные функции. ...

Какой способ рисования в 2D лучше?
Приветствую! Захотел сделать свой контрол, нашел в интеренете аж целых 2 решение моей задачи. З первым вариантом разобрался, второй...

3
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
12.11.2019, 12:59
Лучший ответ Сообщение было отмечено Toros1992 как решение

Решение

T-SQL
1
2
3
4
5
6
7
select
 c.Name, c.ID
from
 Customer c
where
 exists(select 1 from Orders where Customer_ID = c.ID and Product_ID = 1) and
 not exists(select 1 from Orders where Customer_ID = c.ID and Product_ID = 2);
2
 Аватар для Toros1992
899 / 554 / 275
Регистрация: 26.11.2015
Сообщений: 1,758
Записей в блоге: 2
12.11.2019, 13:59  [ТС]
invm, Спасибо. Не подскажите, почему такой запрос будет более эффективным?
0
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
12.11.2019, 15:07
Toros1992, ну если грубо и упрощенно, то:
ваш вариант - таблицы вычитываются дважды + две группировки
мой вариант - вычитывание Customer и два вычитывания Orders, без группировки
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
12.11.2019, 15:07
Помогаю со студенческими работами здесь

Какой способ восстановления ВЖД лучше
Restore Remap Erase

Логи - какой способ лучше выбрать ?
Доброго времени суток. Подскажите какой способ лучше выбрать для ведения логов, для такой задачи: есть приложение Клиент-сервер, на...

Какой способ разгона процессора лучше?
Вопрос к знатокам оверлокерам, каким способом лучше разгонять процессор: при помощи множителя процессора или базового генератора? ...

Какой способ работы с файлами лучше?
Мне известно по крайней мере три способа: 1 TStringList::LoadFromFile 2 std::ofstream 3 FILE *fp = fopen Чем отличаются...

какой способ лучше для базового изучения 8.2
Доброго времени суток! Я работаю с 7кой, по 8.1 есть некоторые теоретические знания. Посоветуйте, пожалуйста, кто знает. Базовый курс ...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Автоматическое создание документа при проведении другого документа
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;. . .
Отправка уведомления на почту при создании или изменении элементов справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи электронной. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru