Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
MySQL на примерах. Авторы: Кузнецов М.В., Симдянов И.В. Самоучитель MySQL 5. Авторы: Кузнецов М.В., Симдянов И.В. PHP 5. На примерах. Авторы: Кузнецов М.В., Симдянов И.В., Голышев С.В. Самоучитель PHP 5 / 6 (3 издание). Авторы: Кузнецов М.В., Симдянов И.В. MySQL 5. В подлиннике. Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум MySQL

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: Оптимизации order by запроса
 
 автор: axxil   (02.08.2005 в 11:02)   письмо автору
 
 

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

Стоит задача оптимизировать запрос select * from table order by field1, field2 desc ,...
Вроде бы простой запрос, но я читал что order сильно тормозит запросы в больших таблицах.

Т.е надо отсортировать оптимальным образом таблицу по четырём её полям в заданом порядке важности сортировки... т.е сначала сортировка по field1, потом по field2 и т.д.

Как это лучше всего реализовать?

   
 
 автор: cheops   (02.08.2005 в 13:13)   письмо автору
 
   для: axxil   (02.08.2005 в 11:02)
 

Ничего здесь сделать нельзя с запросом... можно проиндексировать поля field1, field2 - тогда будет всё быстро или провести сортировку по field1, field2 физически при помощи оператора ALTER TABLE
ALTER TABLE tbl ORDER BY field1, field2

   
 
 автор: Axxil   (02.08.2005 в 13:44)   письмо автору
 
   для: cheops   (02.08.2005 в 13:13)
 

Спасибо.
А эту физическую сортировку надо будет проводить каждый раз? Или достаточно один раз провести а потом новые строки будут добавлятся в порядке заданной сортировки?
И ещё при обычном индексировании надо использовать составной индекс по всем сортировочным полям или необходимо каждое поле проиндексировать?

   
 
 автор: cheops   (02.08.2005 в 13:47)   письмо автору
 
   для: Axxil   (02.08.2005 в 13:44)
 

Нет физическая сортировка только на один раз, она поможет обычной ORDER BY - часто её проводить не следует.

   
 
 автор: Axxil   (02.08.2005 в 13:50)   письмо автору
 
   для: cheops   (02.08.2005 в 13:47)
 

быстро :)
А при обычной сортитровке надо использовать составной индекс или каждое поле надо индексировать отдельно?

   
 
 автор: cheops   (02.08.2005 в 13:55)   письмо автору
 
   для: Axxil   (02.08.2005 в 13:50)
 

Если не планируется использовать столбцы в других операциях (WHERE-условия, другие сортировки) то можно использовать составной индекс, если планируется, то лучше проиндесировать их отдельно.

   
 
 автор: Axxil   (02.08.2005 в 14:20)   письмо автору
 
   для: cheops   (02.08.2005 в 13:55)
 

спасибо большое

   
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования