Mysql. Как указать по каким ключам искасть в первую очередь.

MySQL базы данных

Есть таблица, ищу по 2-м полям. Если ищу по одному полю - ищет по индексу (смотрю explain) все в порядке, скорость запроса в пределах милисекунд. Выглядит примерно так:

....inner join table m on m.side1=d.id....

Если ищу по 2-м полям - беда, на индексы забивает, выгружает *всю* таблицу, и после join-ов отсеивает, 10сек в результате. Выглядит примерно так:

....inner join table m on (m.side1=d.id or m.side2=d.id)....

Что делать? Есть какие-то способы повлиять на выбор приоритетных ключей?
Есть отдельные индексы для side1 и side2 и общий индекс side по обеим полям

Примечание:
>>Не поручусь за MySQL, но в MSSQL наличие OR в условии — это практически
>>гарантированный скан таблицы
В общих случаях проблем нет, но тут довольно сложный запрос.

Примечание:
Ответ найден: FORCE INDEX
Ответы:
Ну... Эм.. как бы можно сделать два запроса по одному полю, а потом тупо склеить таблицы.... как бы типа вот так....
Не поручусь за MySQL, но в MSSQL наличие OR в условии — это практически гарантированный скан таблицы. Видимо, в MySQL то же самое.
В MSSQL помогло бы избавление от OR при помощи UNION. За MySQL, опять же, не поручусь.


11 лет назад

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

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

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