Индексы в MongoDb::Журнал СА 1-2.2014
www.samag.ru
     
Поиск   
              
 www.samag.ru    Web  0 товаров , сумма 0 руб.
E-mail
Пароль  
 Запомнить меня
Регистрация | Забыли пароль?
Журнал "Системный администратор"
Журнал «БИТ»
Наука и технологии
Подписка
Где купить
Авторам
Рекламодателям
Архив номеров
Контакты
   

  Опросы
  Статьи

Электронный документооборот  

5 способов повысить безопасность электронной подписи

Область применения технологий электронной подписи с каждым годом расширяется. Все больше задач

 Читать далее...

Рынок труда  

Системные администраторы по-прежнему востребованы и незаменимы

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

 Читать далее...

Учебные центры  

Карьерные мечты нужно воплощать! А мы поможем

Школа Bell Integrator открывает свои двери для всех, кто хочет освоить перспективную

 Читать далее...

Гость номера  

Дмитрий Галов: «Нельзя сказать, что люди становятся доверчивее, скорее эволюционирует ландшафт киберугроз»

Использование мобильных устройств растет. А вместе с ними быстро растет количество мобильных

 Читать далее...

Прошу слова  

Твердая рука в бархатной перчатке: принципы soft skills

Лауреат Нобелевской премии, специалист по рынку труда, профессор Лондонской школы экономики Кристофер

 Читать далее...

1001 и 1 книга  
19.03.2018г.
Просмотров: 9890
Комментарии: 0
Потоковая обработка данных

 Читать далее...

19.03.2018г.
Просмотров: 8106
Комментарии: 0
Релевантный поиск с использованием Elasticsearch и Solr

 Читать далее...

19.03.2018г.
Просмотров: 8204
Комментарии: 0
Конкурентное программирование на SCALA

 Читать далее...

19.03.2018г.
Просмотров: 5195
Комментарии: 0
Машинное обучение с использованием библиотеки Н2О

 Читать далее...

12.03.2018г.
Просмотров: 5873
Комментарии: 0
Особенности киберпреступлений в России: инструменты нападения и защита информации

 Читать далее...

Друзья сайта  

 Индексы в MongoDb

Архив номеров / 2014 / Выпуск №1-2 (134-135) / Индексы в MongoDb

Рубрика: Разработка /  Веб-технологии

Александр Календарев АЛЕКСАНДР КАЛЕНДАРЕВ, программист, РБК Медиа, akalend@mail.ru

Индексы в MongoDb

Изучая особенности СУБД MongoDb, нельзя не отметить такой важный момент, как индексирование. Правильное построение индексов и оптимизация запросов определяют общую производительность системы

Прежде чем говорить об индексировании, уточним, что такое «индекс».

«Индекс (англ. index) – объект базы данных, создаваемый в целях повышения производительности поиска данных. Таблицы в базе могут иметь большое количество строк, которые хранятся в произвольном порядке, и их поиск по заданному критерию путем последовательного просмотра таблицы строка за строкой может занимать много времени.

Индекс формируется из значений одного или нескольких столбцов таблицы и указателей на соответствующие строки таблицы и, таким образом, позволяет искать строки, удовлетворяющие критерию поиска. Ускорение работы с использованием индексов достигается в первую очередь за счет того, что индекс имеет структуру, оптимизированную под поиск, – например, сбалансированного дерева. Как мы уже поняли из определения, индексы нужны для уменьшения времени выборки, что увеличивает производительность БД. В большинстве случаев переход на разные NoSQL-решения связан именно с недостаточной производительностью традиционных РСУБД.» (Wikipedia.org)

Наиболее производительная выборка документов будет в том случае, если на поля, по которым планируется осуществлять критерий выбора, наложить индекс. Это дает возможность более быстрого выбора за счет использования индекса, который ограничивает нам набор данных для их дальнейшей фильтрации и упорядочивания.

Внутреннее устройство индекса

Как устроен индекс? Это внутренняя таблица в БД, которая имеет два столбца: упорядоченные значения выражения, содержащего необходимые для идентификации поля конкретной записи, и адрес области на носителе, где элементы данных этой записи.

Рассмотрим, как устроен индекс, на примере работы службы знакомств. Нам необходимо найти всех девушек в возрасте от 25 до 35 лет, используя следующие данные (см. таблицу 1). Индекс по полю «возраст» («age») будет выглядеть следующим образом (см. рис. 1).

Таблица 1. Данные зарегистрированных пользователей

sex city_id age name offset
0 77 35 Михаил 0xA01
1 78 19 Мария 0xA20
1 78 21 Лилия 0xA2C
0 77 31 Евгений 0xA04
1 77 26 Елена 0xA24
1 77 31 Ольга 0xA02
1 78 31 Вероника 0xA2A

Рисунок 1. Индекс по полю «возраст» («age»)

Рисунок 1. Индекс по полю «возраст» («age»)

Подходящие данные по нашему критерию – возраст от 25 до 35 лет – обведены красной линией. Далее выбираются документы со смещениями 0xA24, 0xA24, 0xA02, 0xA2A и фильтруются на выборку по критерию sex=1 (не забыли, выбираем только девушек). Как мы видим, вместо полного перебора по всему диапазону коллекции мы отобрали по индексу только соответствующих по возрасту и далее отфильтровали их по критерию пол (sex). Документ со смещением 0xA04 не вошел в результирующее множество (помечен серо-розовым цветом), так как не удовлетворяет критерию: sex=1.

Статью целиком читайте в журнале «Системный администратор», №1-2 за 2014 г. на страницах 94-97.


Комментарии отсутствуют

Добавить комментарий

Комментарии могут оставлять только зарегистрированные пользователи

               Copyright © Системный администратор

Яндекс.Метрика
Tel.: (499) 277-12-41
Fax: (499) 277-12-45
E-mail: sa@samag.ru