Модераторы: skyboy
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Оптимизация OR при JOIN 
:(
    Опции темы
maxipub
Дата 4.1.2019, 18:53 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 517
Регистрация: 22.10.2009

Репутация: 1
Всего: 1



Здравствуйте!

Подобный запрос:
Код
SELECT * FROM t1 LEFT JOIN t2 ON (t2.id=t1.id OR t2.sub_id=t1.sub_id)


Будет выполняться долго даже на небольших таблицах из-за того, что индексы не будут использованы. Насколько я знаю, там есть какие-то проблемы с индексами при OR.

Это можно как-то решить кроме как переделками вида:

Код
SELECT * FROM t1 LEFT JOIN t2 t21 ON (t21.id=t1.id) LEFT JOIN t2 t22 ON (t22.sub_id=t1.sub_id)


?

Спасибо!
PM MAIL   Вверх
Akina
Дата 4.1.2019, 23:08 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


Профиль
Группа: Модератор
Сообщений: 20570
Регистрация: 8.4.2004
Где: Зеленоград

Репутация: 106
Всего: 453



Цитата(maxipub @  4.1.2019,  19:53 Найти цитируемый пост)
Насколько я знаю, там есть какие-то проблемы с индексами при OR.

Они есть везде. 

Цитата(maxipub @  4.1.2019,  19:53 Найти цитируемый пост)
Это можно как-то решить кроме как переделками вида

Эта "переделка" задачу не решит.

В зависимости от структуры хранения и статистики данных возможны разные "заменители". Большинство - это различные UNION.


--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | MySQL | Следующая тема »


 




[ Время генерации скрипта: 0.0972 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.