Запросить дату между сегодняшним днем ​​и ближайшими 6 месяцами

Я пытаюсь запросить свою базу данных, чтобы получить все инфраструктуры со сроком выполнения (inf_lifespan) через 6 месяцев от сегодняшней даты.

inf_lifespan
2028-09-19
2025-12-04
2020-11-11
2026-02-17
2019-12-12
2020-11-13
2018-12-13

Выполнение этого запроса не приведет к созданию записи, но я ожидаю, что инфраструктура со сроком выполнения 13 декабря 2018 г. должна быть результатом запроса.

select * 
from tbl_infrastructure 
where `inf_lifespan` BETWEEN DATE_SUB( CURDATE( ) ,INTERVAL 6 MONTH ) AND DATE_SUB( CURDATE( ) ,INTERVAL 0 MONTH )

Я использую 5.7.21 - Сервер сообщества MySQL (GPL)

Кто-нибудь может мне помочь с этим, пожалуйста

Какой продукт СУБД вы используете? «SQL» - это просто язык запросов, а не имя конкретного продукта базы данных (и в стандартном SQL нет date_sub, и эти ужасные обратные кавычки также недопустимы в стандартном SQL). Добавьте ярлык для продукта базы данных, который вы используете postgresql, oracle, sql-server, db2, ...

a_horse_with_no_name 17.09.2018 10:20
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для разработчиков
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для разработчиков
В последние годы архитектура микросервисов приобрела популярность как способ построения масштабируемых и гибких приложений. Laravel , популярный PHP...
Как построить CRUD-приложение в Laravel
Как построить CRUD-приложение в Laravel
Laravel - это популярный PHP-фреймворк, который позволяет быстро и легко создавать веб-приложения. Одной из наиболее распространенных задач в...
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
В предыдущем посте мы создали функциональность вставки и чтения для нашей динамической СУБД. В этом посте мы собираемся реализовать функции обновления...
Документирование API с помощью Swagger на Springboot
Документирование API с помощью Swagger на Springboot
В предыдущей статье мы уже узнали, как создать Rest API с помощью Springboot и MySql .
Роли и разрешения пользователей без пакета Laravel 9
Роли и разрешения пользователей без пакета Laravel 9
Этот пост изначально был опубликован на techsolutionstuff.com .
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
В предыдущей статье мы завершили установку базы данных, для тех, кто не знает.
1
1
45
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

В состоянии BETWEEN DATE_SUB( CURDATE( ) ,INTERVAL 6 MONTH ) AND DATE_SUB( CURDATE( ) ,INTERVAL 0 MONTH )

вы увидите дату с 6 месяцев назад до сегодняшнего дня.

Вы можете попробовать использовать DATE_ADD вместо DATE_SUB, потому что функция DATE_SUB не соответствует месяцу.

select * 
from tbl_infrastructure 
where `inf_lifespan` BETWEEN CURDATE() AND DATE_ADD( CURDATE(), INTERVAL 6 MONTH)

Другие вопросы по теме