Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.96/302: Рейтинг темы: голосов - 302, средняя оценка - 4.96
0 / 0 / 0
Регистрация: 11.11.2017
Сообщений: 7

Запрос, возвращающий список всех клиентов, совершивших заказ за определенный период времени

15.11.2017, 17:51. Показов 58188. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Cформулируйте запрос, возвращающий список всех клиентов (с указанием фамилии и имени), совершивших заказ за определенный период времени
Две таблицы: Customer и Order
Значения в Customer: IdCust - код заказчика, FName - Имя, LName - Фамилия, IdCity - Код города, Adress - Адрес, Zip - Индекс и Phone - Телефон
Значения в Order: IdOrd - Код заказа, IdCust - код заказчика, ordDate - дата
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
15.11.2017, 17:51
Ответы с готовыми решениями:

Запрос, возвращающий список всех клиентов, совершивших более 3 заказов
Добрый день. Дано: 1-я таблица Commande (id_commande, id_client, date_commande) 2-я таблица Clients (id_client, Name, Phone, Adress) ...

Нужен запрос, подсчитывающий количество клиентов, ни сделавших ни одного заказа в определенный период времени
Всем привет! Срочно нужна помощь в составлении sql запроса! Итак есть 2 таблицы: member( в ней хранится информация о клиентах) и...

SQL запрос, который вернет список клиентов, не совершивших ни одной транзакции
Доброй ночи, уважаемые мастера SQL! Помогите, пожалуйста, решить задачу (сам на entry level'e и имею лишь небольшой опыт): ...

7
5984 / 4559 / 1095
Регистрация: 29.08.2013
Сообщений: 28,197
Записей в блоге: 3
15.11.2017, 18:56
Лучший ответ Сообщение было отмечено alexmafacka как решение

Решение

SQL
1
2
3
4
SELECT c.*
FROM ORDER o
JOIN Customer c ON o.IdCust =c.IdCust 
WHERE o.ordDate BETWEEN '20170101' AND '20171101'
запросвыдаст список ВСЕХ клиентов
если не нужны дубли, то нужно сгруппировать
1
0 / 0 / 0
Регистрация: 11.11.2017
Сообщений: 7
15.11.2017, 19:12  [ТС]
qwertehok, Работает, есть ещё одно условие задачи и надеюсь отстану
Список клиентов, которые за заданный период (например, сентябрь 2010 года) совершили более 3 заказов.
Значения в Customer: IdCust - код заказчика, FName - Имя, LName - Фамилия, IdCity - Код города, Adress - Адрес, Zip - Индекс и Phone - Телефон
Значения в Order: IdOrd - Код заказа, IdCust - код заказчика, ordDate - дата
Значения в OrderItem: IdOrd- Код заказа, IdProd - код продукта или товара, Qty - количество заказов, Price - цена одного заказа
0
5984 / 4559 / 1095
Регистрация: 29.08.2013
Сообщений: 28,197
Записей в блоге: 3
15.11.2017, 19:49
третья таблица тут не нужна

SQL
1
2
3
4
5
6
7
8
SELECT * FROM Customer WHERE IdCust IN (
SELECT IdCust FROM ORDER o
JOIN (
SELECT IdOrd, COUNT(IdCust) FROM ORDER WHERE datepart(YEAR,ordDate)='2017' AND datepart(MONTH,ordDate)='9'
GROUP BY IdOrd
HAVING COUNT(IdCust)>3
) t ON o.IdOrd =t.IdOrd 
)
не очень красиво, но работает
1
0 / 0 / 0
Регистрация: 11.11.2017
Сообщений: 7
15.11.2017, 19:56  [ТС]
qwertehok, выдало ошибку: "Сообщение 8155, уровень 16, состояние 2, строка 7
Для столбца 2 таблицы "t" не указано имя."
0
5984 / 4559 / 1095
Регистрация: 29.08.2013
Сообщений: 28,197
Записей в блоге: 3
16.11.2017, 07:40
4я строка
вот это
SQL
1
SELECT IdOrd, COUNT(IdCust)
заменить на
SQL
1
SELECT IdOrd, COUNT(IdCust) AS Количество
1
0 / 0 / 0
Регистрация: 09.12.2018
Сообщений: 3
19.03.2019, 03:45
Добрый день.
У меня чем-то похожая ситуация.
Дано:
1-я таблица заказы
2-я таблица клиенты

Таблицы связаны по id_client

Задача вывести клиентов из таблицы клиентов, те которые совершили более 3 заказов в таблице заказов.

Надеюсь доступно написал. Спасибо.
0
14 / 11 / 5
Регистрация: 14.03.2019
Сообщений: 43
Записей в блоге: 1
19.03.2019, 10:50
Цитата Сообщение от kipiwpartner Посмотреть сообщение
Добрый день.
У меня чем-то похожая ситуация.
Дано:
1-я таблица заказы
2-я таблица клиенты
Таблицы связаны по id_client
Задача вывести клиентов из таблицы клиентов, те которые совершили более 3 заказов в таблице заказов.
Надеюсь доступно написал. Спасибо.
T-SQL
1
select * from Клиенты where id_client in (select id_client from Заказы group by id_client having count(*) > 3)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
19.03.2019, 10:50
Помогаю со студенческими работами здесь

Создать запрос, который бы считал сколько сколько процентов набежало за определенный период времени
Добрый день, всем участникам форума. Не могу справится с задачей. есть таблица "договора займа предприятия"- столбцы(...

Копирование файлов за определенный период времени
Добрый день, Нужна помощь, задача: есть папка ARC, в ней находятся файлы *.log. Необходимо чтобы в папке находились файлы только за...

Шифрование ссылок на определенный период времени
Добрый день! Подскажите пожалуйста решение такой ситуации, есть ссылка со стороннего сайта для скачивания архива. Как можно сделать так,...

Создание таймер с остановкой в определенный период времени
Всем Привет! Мне нужно написать программу-таймер, которая будет выводить пользователю сообщение каждые 5 минут. Тоесть нажал кнопку,...

Защита файла от редактирования в определенный период времени
Доброго времени суток . Возникла необходимость запрета файла Excel по времени. Точнее после 14 00 файл нужно запретить редактировать . ...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: 1. Реализовать контроль заполнения реквизита. . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru