Я пытаюсь запросить свою базу данных, чтобы получить все инфраструктуры со сроком выполнения (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)
Кто-нибудь может мне помочь с этим, пожалуйста






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