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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> оптимизация order by... поле типа double 
:(
    Опции темы
sergey_85
Дата 5.1.2012, 08:43 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 445
Регистрация: 17.4.2007
Где: Россия, Челябинск

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



Привет!

Как можно оптимизирвать этот запрос, очееень долго выполняется

Код

select SQL_CALC_FOUND_ROWS * from tbl_stellbeton  
order by tbl_stellbeton.price asc limit 0, 100



хотя этот за пару секунд

Код

select SQL_CALC_FOUND_ROWS * from tbl_stellbeton  
order by tbl_stellbeton.id asc limit 0, 100


id - primary index asc
price - index asc


--------------------
A good design always pays off.
PM MAIL   Вверх
Akina
Дата 5.1.2012, 20:24 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


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


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

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



explain запросов дайте...


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

PM MAIL WWW ICQ Jabber   Вверх
sergey_85
Дата 9.1.2012, 02:15 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 445
Регистрация: 17.4.2007
Где: Россия, Челябинск

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




Код


 select SQL_CALC_FOUND_ROWS *
 from tbl_stellbeton  
 order by tbl_stellbeton.id asc limit 0, 100

id,select_type,table,type,possible_keys,key,key_len,ref,rows,Extra
1,SIMPLE,tbl_stellbeton,index,NULL,PRIMARY,4,NULL,97005,



Код

 select SQL_CALC_FOUND_ROWS *
 from tbl_stellbeton  
 order by tbl_stellbeton.price asc limit 0, 100

id,select_type,table,type,possible_keys,key,key_len,ref,rows,Extra
1,SIMPLE,tbl_stellbeton,ALL,NULL,NULL,NULL,NULL,97005,"Using filesort"



Это сообщение отредактировал(а) sergey_85 - 9.1.2012, 02:18


--------------------
A good design always pays off.
PM MAIL   Вверх
Goganchic
Дата 9.1.2012, 07:52 (ссылка) |    (голосов:2) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



рискну предположить что у вас слишком много строк (более 50%) с одинаковой ценой, поэтому индекс получается низкоселективный и поэтому MySQL его не использует, из-за чего случается filesort, который приводит к тормозам
PM Jabber   Вверх
Akina
Дата 9.1.2012, 21:50 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


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


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

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



Один запрос выбирает по индексу, а второй прямым просмотром... стОит ли удивляться разнице во времени?


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

PM MAIL WWW ICQ Jabber   Вверх
sergey_85
Дата 10.1.2012, 02:10 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 445
Регистрация: 17.4.2007
Где: Россия, Челябинск

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



есть предложения как побороть?


--------------------
A good design always pays off.
PM MAIL   Вверх
Akina
Дата 10.1.2012, 07:33 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


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


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

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



Создать необходимый индекс.


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

PM MAIL WWW ICQ Jabber   Вверх
Zloxa
Дата 10.1.2012, 11:45 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


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

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



индекс, я так понял уже есть, его надо просто форсить.


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
sergey_85
Дата 13.1.2012, 05:46 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 445
Регистрация: 17.4.2007
Где: Россия, Челябинск

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



да есть у меня индексы и были они ....

'tbl_stellbeton', '0', 'PRIMARY', '1', 'id', 'A', '102939', NULL, NULL, '', 'BTREE', '', ''
'tbl_stellbeton', '1', 'idx_price', '1', 'price', 'A', '102939', NULL, NULL, 'YES', 'BTREE', '', ''


еще таже самая проблема с where

долго
Код

select SQL_CALC_FOUND_ROWS * from tbl_stellbeton 
where price>1000  limit 0, 100


быстро
Код

select SQL_CALC_FOUND_ROWS * from tbl_stellbeton 
where id>1000  limit 0, 100


ps: mysql version - '5.5.13'
данных в таблице ОЧЕНЬ много!


Это сообщение отредактировал(а) sergey_85 - 13.1.2012, 06:02


--------------------
A good design always pays off.
PM MAIL   Вверх
Zloxa
Дата 13.1.2012, 08:40 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


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

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



Цитата(sergey_85 @  13.1.2012,  05:46 Найти цитируемый пост)
да есть у меня индексы

индексы мало есть. Их надо еще использовать. Хинт прописывать пробовали?

Это сообщение отредактировал(а) Zloxa - 13.1.2012, 08:41


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
sergey_85
Дата 14.1.2012, 05:58 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 445
Регистрация: 17.4.2007
Где: Россия, Челябинск

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



Цитата(Zloxa @ 13.1.2012,  08:40)
Цитата(sergey_85 @  13.1.2012,  05:46 Найти цитируемый пост)
да есть у меня индексы

индексы мало есть. Их надо еще использовать. Хинт прописывать пробовали?

разве оптимизатор сам не определяет где и как исп. индексы...


--------------------
A good design always pays off.
PM MAIL   Вверх
Zloxa
Дата 14.1.2012, 07:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


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

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



Goganchic выдвинул вполне правдоподобную версию почему оптимизатор этого не делает.


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | MySQL | Следующая тема »


 




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


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

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