mysql диапазоны дат

MySQL sql база

В таблице записаны диапазоны дат
datefrom || dateto
Юзер вводит свой диапазон, и должны вывестись даты которые входят в его диапазон например

25.05.13 || 04.06.13
05.06.13 || 14.06.13
15.06.13 || 30.06.13
01.07.13 || 20.07.13

пользователь указал с 29-05.13 по 20.06.13 и ему выводятся первые три
пробовал
( '.$datefrom.' BETWEEN per.`datefrom` AND per.`dateto` OR '.$dateto.' BETWEEN per.`datefrom` AND per.`dateto`) но так пропустится 2 диапазон.

Примечание:
сделал так
( UNIX_TIMESTAMP(STR_TO_DATE("' .$data['date_from'] . '","%Y.%m.%d")) <= UNIX_TIMESTAMP(per.`dateto`) OR UNIX_TIMESTAMP(STR_TO_DATE("' $data['date_to']) . '","%Y.%m.%d")) => UNIX_TIMESTAMP(per.`datefrom`))
Ответы:
Никогда не пользуйся BETWEEN, потому что он не использует индексы и в результате всё тормозит. А вот больше и меньше - чётко идут по индексу.
Между условиями должен стоять оператор and, а не or. C or условие всегда истинно.


12 лет назад

RPI.su - самая большая русскоязычная база вопросов и ответов. Наш проект был реализован как продолжение популярного сервиса otvety.google.ru, который был закрыт и удален 30 апреля 2015 года. Мы решили воскресить полезный сервис Ответы Гугл, чтобы любой человек смог публично узнать ответ на свой вопрос у интернет сообщества.

Все вопросы, добавленные на сайт ответов Google, мы скопировали и сохранили здесь. Имена старых пользователей также отображены в том виде, в котором они существовали ранее. Только нужно заново пройти регистрацию, чтобы иметь возможность задавать вопросы, или отвечать другим.

Чтобы связаться с нами по любому вопросу О САЙТЕ (реклама, сотрудничество, отзыв о сервисе), пишите на почту [email protected]. Только все общие вопросы размещайте на сайте, на них ответ по почте не предоставляется.