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

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

02.11.2015, 15:35. Показов 3053. Ответов 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
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru