0 / 0 / 0
Регистрация: 01.11.2015
Сообщений: 123
MS Access

SQL: найти разницу между текущей датой и датой заключения договора

02.11.2015, 15:35. Показов 3042. Ответов 5

Студворк — интернет-сервис помощи студентам
Здравствуйте! Помогите, пожалуйста, с запросом SQL.
Есть база данных в Access. В С++ Builder 6 подключены компоненты ADOConnection, ADOQuery, DataSource для связывания с БД и компонент DBGrid для отображения результата работы sql-запроса.
В таблице договор хранится Дата заключения договора. Нужно найти разницу между текущей датой и датой заключения договора и вывести данные, где результаты вычислений больше 6 месяцев.

Запрос в таком виде:
SQL
1
2
3
4
SELECT Klient.Imia_klienta, Dogovor.Data_zakluchenia, Dogovor.Yslovia_sotrydnichestva, Dogovor.Srok_deistvia
FROM Klient, Dogovor
WHERE Dogovor.Kod_klienta=Klient.Kod_klienta
AND ('2015-11-02'-[Dogovor.Data_zakluchenia]>'%-06-%')
Как переделать запрос?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
02.11.2015, 15:35
Ответы с готовыми решениями:

Как получить разницу в днях между текущей датой и датой записанной в прогу mssql базы во время выборки?
Как получить разницу в днях между текущей датой и датой записанной в пролу mssql базы во время выборки. т.е что то типо select * from...

Определить разницу между текущей и введенной датой
Используя класс , определить разницу между текущей и введенной датой. Добавлено через 4 часа 0 минут точнее сказать не класс а...

Разность между текущей датой и датой последней покупки
Помогите пожалуйста. Как можно посчитать давность покупки?как это запросом написать? (это вообще разность между текущей датой и датой...

5
480 / 393 / 113
Регистрация: 24.04.2012
Сообщений: 1,632
Записей в блоге: 3
03.11.2015, 04:25
должна быть функция DateDiff.
Запрос SQL. Примеры в MS Access

Не по теме:

так то есть поисковики

1
Эксперт Pascal/Delphi
 Аватар для xxbesoxx
1135 / 616 / 129
Регистрация: 13.02.2009
Сообщений: 3,600
03.11.2015, 19:01
Лучший ответ Сообщение было отмечено Tatiana21 как решение

Решение

Цитата Сообщение от Tatiana21 Посмотреть сообщение
В таблице договор хранится Дата заключения договора. Нужно найти разницу между текущей датой и датой заключения договора и вывести данные, где результаты вычислений больше 6 месяцев.
Смотрим функцию DATEDIFF http://www.techonthenet.com/ac... tediff.php что мы сможем вычислять и начинаем
SQL
1
2
3
SELECT id, Date_Dogovor, Imia_klienta, DATEDIFF("m", Date_Dogovor, DATE() ) AS Month_Mesiac
FROM Dogovor
WHERE DATEDIFF("m", Date_Dogovor, DATE() ) >6
Вложения
Тип файла: rar 1.rar (11.4 Кб, 6 просмотров)
1
0 / 0 / 0
Регистрация: 01.11.2015
Сообщений: 123
03.11.2015, 19:41  [ТС]
Спасибо за ответы! Я сделала немножко по-другому, тоже работает:
SQL
1
2
3
4
5
SELECT Klient.Imia_klienta, Dogovor.Data_zakluchenia, Dogovor.Yslovia_sotrydnichestva, Dogovor.Srok_deistvia,  
DateDiff("m",Dogovor.Data_zakluchenia,DATE())-iif(DAY(Dogovor.Data_zakluchenia)>DAY(DATE()),1,0) AS Proshlo_polnnih_mesiacev
FROM Klient, Dogovor
WHERE Dogovor.Kod_klienta=Klient.Kod_klienta AND DateDiff("m",Dogovor.Data_zakluchenia,DATE())-iif(DAY(Dogovor.Data_zakluchenia)>DAY(DATE()),1,0) >=6
GROUP BY Klient.Imia_klienta, Dogovor.Data_zakluchenia, Dogovor.Yslovia_sotrydnichestva, Dogovor.Srok_deistvia
Добавлено через 6 минут
0
Эксперт Pascal/Delphi
 Аватар для xxbesoxx
1135 / 616 / 129
Регистрация: 13.02.2009
Сообщений: 3,600
03.11.2015, 19:51
Лучший ответ Сообщение было отмечено Tatiana21 как решение

Решение

Так правильно
SQL
1
2
3
4
5
6
SELECT Klient.Imia_klienta, Dogovor.Data_zakluchenia, Dogovor.Yslovia_sotrydnichestva, Dogovor.Srok_deistvia,
DateDiff("m",Dogovor.Data_zakluchenia,DATE()) AS Proshlo_polnnih_mesiacev
FROM Klient, Dogovor
WHERE Klient.ID=Dogovor.ClientID
-- Если БД спроектировано правильно .!  должен связь (один ко многим) один и тот же клиент может делаеть несколько договор
AND  DateDiff("m",Dogovor.Data_zakluchenia,DATE()) >6
1) >=6 почему ? если сказано что --> вывести данные, где результаты вычислений больше 6 месяцев.
2) GROUP BY почему ?
1
0 / 0 / 0
Регистрация: 01.11.2015
Сообщений: 123
03.11.2015, 21:18  [ТС]
Спасибо за ответ. Исправлю указанные ошибки. Действительно Group by в данном запросе не нужно и = лишнее.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
03.11.2015, 21:18
Помогаю со студенческими работами здесь

Как сравнить правильно в MySQL запросе поле с датой с текущей датой?
Всем привет! Как сравнить правильно в mysql запросе поле с датой с текущей датой? Мне просто нужно, чтобы скрипт перезаписывал значение...

Определить разницу между заданной датой/временем
Всем доброго дня, Имеется задача определить количество часов между двумя точками отсчета выбранных при помощи DataTimePicker в формате...

Разница между входящей датой и текущей
На вход подается дата в формате 10.06.2016 22:00:00 на выходе нужно получить сколько дней осталось. у меня есть функция ...

Как заполнить промежуток между начальной датой и конечной датой в пустой таблице?
Возможно ли в MS Accsee в пустой таблице заполнить автоматически промежуток(период) между начальной и конечной датами и как это...

Установить соответствующую дату и вычислить разность между ней и текущей датой
Вообщем, задание состоит в следующем: установить соответствующую дату и вычислить разность между ней и текущей датой. Так вот, данная...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Опции темы

Новые блоги и статьи
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru