Правила     Закладки     Карма    Календарь    Журналы    Помощь    Поиск    PDA    Чат   
        СМС-ки
   
Пейджер выключен!
 
Фильтр авторов:    показать 
  скрыть
  Ответ в темуСоздание новой темыСоздание опроса

> Разные explain, на один и тот же запрос
Ron  
 ۩  [x] Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Здесь живет
******

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 1045
Пользователь №: 41686
На форуме: 1 год, 3 месяца, 29 дней
Карма: 13




Ребята, привет!

У меня чего-то мозг взрывается.

Есть один и тот же запрос, только с разными значениями WHERE. Все полностью одно и тоже, за исключением конкретных цифр по конкретным полям. Даже не то, что по полям - по одному полю!

Получаю разные explain с эпично разным временем выполнения...

Что за фигня происходит!? Где-то целостность данных полетела? Как искать причину такого поведения СуБД?

Вот первый запрос:
SELECT 
t2.tree_length,
t1.*
FROM
catalog AS t1
INNER JOIN
tree AS t2
ON
t1.catalog_id = t2.tree_descendant
WHERE
t2.tree_ancestor = 1554 AND
t2.tree_length=1
ORDER BY
t1.catalog_displayorder,
t1.catalog_id

На него explain:
+----+-------------+-------+--------+--------------------------------------------------+---------+--- ------+------------------------------------+------+----------------------------------------------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+----+-------------+-------+--------+--------------------------------------------------+---------+-- -------+------------------------------------+------+----------------------------------------------+
| 1 | SIMPLE | t2 | ref | PRIMARY,fk_tree_catalog1,fk_tree_catalog2 | PRIMARY | 4 | const | 138 | Using where; Using temporary; Using filesort |
| 1 | SIMPLE | t1 | eq_ref | PRIMARY | PRIMARY | 4 | zapchast.t2.tree_descendant | 1 | NULL |
+----+-------------+-------+--------+--------------------------------------------------+---------+-- -------+------------------------------------+------+----------------------------------------------+



Абсолютно тот же самый запрос, но t2.tree_ancestor = 361 explain уже вот такой:


+----+-------------+-------+--------+---------------------------------------------------+---------+-- -------+---------------------------------+-------+----------------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+----+-------------+-------+--------+---------------------------------------------------+---------+- --------+---------------------------------+-------+----------------+
| 1 | SIMPLE | t1 | ALL | PRIMARY | NULL | NULL | NULL | 13730 | Using filesort |
| 1 | SIMPLE | t2 | eq_ref | PRIMARY,fk_tree_catalog1,fk_tree_catalog2 | PRIMARY | 8 | const,zapchast.t1.catalog_id | 1 | Using where |
+----+-------------+-------+--------+---------------------------------------------------+---------+- --------+---------------------------------+-------+----------------+




Чего делать?






--------------------
Жду 5.11.2017
PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
Ron  
 ۩  Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Здесь живет
******

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 1045
Пользователь №: 41686
На форуме: 1 год, 3 месяца, 29 дней
Карма: 13




Сам допёр. Видимо оптимизатор начинает выполнение запроса с той таблицы, в которой по запросу проходит наименьшее количество строк. Просто индекса не хватало одного.

Сколько же я еще багов выловлю из этого проекта!? Простые закончились, начались посложнее. biggrin.gif


--------------------
Жду 5.11.2017
PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
  Быстрый ответ
Информация о Госте
Введите Ваше имя
Кнопки кодов
Для вставки цитаты, выделите нужный текст и
НАЖМИТЕ СЮДА
Введите сообщение
Смайлики
:huh:  :o  ;) 
:P  :D  :lol: 
B)  :rolleyes:  <_< 
:)  :angry:  :( 
:unsure:  :blink:  :ph34r: 
     
Показать всё

Опции сообщения  Включить смайлики?
 Включить подпись?
 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:

Опции темы Ответ в темуСоздание новой темыСоздание опроса