Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

Работа индексов

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных
Предыдущая тема :: Следующая тема  
Автор Сообщение
drewblin



Зарегистрирован: 12.02.2010
Сообщения: 1

СообщениеДобавлено: Пт Фев 12 2010 22:25    Заголовок сообщения: Работа индексов Ответить с цитатой

Использую MySQL

Есть таблица ААА (порядка 3 млн. записей):
id int unsigned
addr int unsigned
prod int unsigned
На ней существует 2 индекса: (prod, addr) и (prod)

Запрос
Код:
select distinct addr
from AAA USE INDEX (prod_addr)
where
   prod IN (много значений)

выполняется за 0.2 секунды

Запрос
Код:
select distinct addr
from AAA USE INDEX (prod)
where
   prod IN (много значений)

выполняется за 17 секунд

Выборки возвращают по 2 тысячи записей. Если объем таблицы меньше (сотни тысяч записей) то оба запроса работабт почти одинаково.

Принципиально мне понятно, почему возникает разницаво времени - в первом случае достаточно только индекса чтобы выдать результат.
Во втором - надо еще побегать по таблице, чтобы получить нужне значения.

Сам вопрос: почему такая огромная разница? В моем представлении в индексе хранится адрес записи - остается только перейти на нужный адрес.
Более точно: такая проблема - это особенность MySQL или кривизна настроек? Если второе - то что надо настраивать?
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
критикан



Зарегистрирован: 18.02.2005
Сообщения: 247

СообщениеДобавлено: Пн Мар 29 2010 11:41    Заголовок сообщения: дублирование индексов -- есть ли более полезное дело? Ответить с цитатой

дело тут не в настройках, а в том, что при оптимизации индекс используется не только при обработке слова "уэре", но и слова "дистинкт". в твоём случае для оптимизации "уэре" оба индекса действуют однох...венно, то есть одинаково, а вот для оптимизации слова "дистинкт" индекс прод_аддр подходит лучше. вот и ускорение
----------------------------------------------------
дублирование индексов -- есть ли более полезное дело?
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...