Форум программистов, компьютерный форум, киберфорум
C++ Builder: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/15: Рейтинг темы: голосов - 15, средняя оценка - 4.73
0 / 0 / 0
Регистрация: 01.11.2015
Сообщений: 123
MS Access

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

02.11.2015, 15:35. Показов 3033. Ответов 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
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru