Мне нужно сравнить один диапазон дат для бронирований, если они доступны например, клиент отправляет 21-03-2018 на 25-03-2018, сервер возвращает все доступные бронирования, которые не входят в этот диапазон из базы данных.
List<Booking> findByStarDateBetween(Date start, Date end);
List<Booking> findByEndDateBetween(Date start, Date end);
мне нужно идти по индивидуальному запросу?
db table
Booking
int id;
Date startDate;
Date endDate;






Вы можете присоединяйтесь к условиям. Следовательно, ваш код будет:
List<Booking> results = findByStartDateBeforeAndEndDateAfter(startDate, endDate);
Надеюсь, это поможет. Если нет, оставьте, пожалуйста, комментарий.
Вы могли бы, я не знаю, попробовать?
+1 за подсказку с условиями присоединения, хотя, допустим, есть бронирование от 22 до 29, а в базе данных есть бронирование от 21 до 30, оно будет перекрывать его. Я ищу что-то вроде findByStarDateBetweenNotAndEndDateBetweenNot (Дата начала, Дата окончания)