Изменения документа Индексы

Редактировал(а) Alexandr Fokin 2024/04/29 13:39

<
От версии < 11.4 >
отредактировано Alexandr Fokin
на 2024/03/24 14:36
К версии < 7.5 >
отредактировано Alexandr Fokin
на 2022/07/11 19:32
>
Изменить комментарий: Update document after refactoring.

Комментарий

Подробности

Свойства страницы
Родительский документ
... ... @@ -1,1 +1,1 @@
1 -Разработка.Базы данных.Механизмы.WebHome
1 +Разработка.Базы данных.SQL.Механизмы.WebHome
Теги
... ... @@ -1,1 +1,1 @@
1 -Индекс|index|Full text search
1 +Индекс|index|Полнотекстовый поиск
Содержимое
... ... @@ -1,82 +1,47 @@
1 -|Основные тезисы|1) Индексы ускоряют поиск данных в таблице, но замедляют вставку и редактирование (если изменяются столбцы задействованные хотя бы в одном индексе).
1 +=== Основные тезисы: ===
2 +
3 +1) Индексы ускоряют выборку данных из таблицы, но замедляют вставку и редактирование (если изменяются столбцы задействованные хотя бы в одном индексе).
2 2  2) При создании индексов стоит учитывать:
3 3  2.1) Как часто с данной таблицей будут производиться операции чтения/записи.
4 4  2.2) Какие конкретно запросы будут выполняться. (по каким полям будет идти поиск, соединение, группировка, сортировка: WHERE, JOIN)
5 5  2.3) Предполагаемые размеры таблицы.
6 -3) Также в определенных запросах индекс может использоваться для более быстрого выполнения операции сортировки, группировки, соединения.
7 -|Кластерный (кластеризованный ) индекс|(((
8 -|(% style="width:154px" %) |(% style="width:1191px" %)Данный индекс определяет порядок строк в таблице, может существовать только в единственном экземпляре.
9 -При вставке новой записи в таблицу рассчитывается значение кластеризованного индекса для новой строки, на основе которого выполняется вставка в имеющийся набор строк.
10 -
11 -|(% style="width:154px" %) |(% style="width:1191px" %)Для таблицы может быть только 1 кластеризованный индекс. Обычно совпадает с первичным ключом. Также в таблице может отсутствовать кластерный индекса (строки будут расположены в порядке их добавления).
12 -|(% style="width:154px" %) |(% style="width:1191px" %)Postgres не содержит кластерных индексов
13 13  
14 -
15 -)))
16 -| |
9 +----
17 17  
18 -(% class="wikigeneratedid" %)
19 -=== ===
11 +==== Критерий - кластеризованный индекс ====
20 20  
21 -=== ===
13 +Кластеризованный индекс
14 +Данный индекс определяет порядок строк в таблице.
15 +При вставке новой записи в таблицу рассчитывается значение кластеризованного индекса для новой строки, на основе которого выполняется вставка в имеющийся набор строк.
16 +Для таблицы может быть только 1 кластеризованный индекс. Обычно совпадает с первичным ключом. Также в таблице может отсутствовать кластеризованного индекса (строки будут расположены в порядке их добавления).
22 22  
18 +Некластеризованный индекс
19 +Не влияет на физический порядок строк. Используется для оптимизации выборки данных.
23 23  
24 24  ----
25 25  
26 -|(% style="width:165px" %) |(% style="width:1328px" %)
23 +Вопросы
24 +1) Оценка состояния индексов. Поддержка индексов в актуальном состоянии.
25 +Критерии состояния индекса (фрагментация).
26 +Действия по обслуживанию индекса (перестроение, пересоздание).
27 27  
28 28  ----
29 29  
30 -==== Внутренние ссылки: ====
31 -
32 -====== Дочерние страницы: ======
33 -
34 34  {{children/}}
35 35  
36 -====== Обратные ссылки: ======
37 -
38 -{{velocity}}
39 -#set ($links = $doc.getBacklinks())
40 -#if ($links.size() > 0)
41 - #foreach ($docname in $links)
42 - #set ($rdoc = $xwiki.getDocument($docname).getTranslatedDocument())
43 - * [[$escapetool.xml($rdoc.fullName)]]
44 - #end
45 -#else
46 - No back links for this page!
47 -#end
48 -{{/velocity}}
49 -
50 50  ----
51 51  
52 52  **Ссылки:**
53 53  
54 -(% style="width:1188px" %)
55 -|(% colspan="1" rowspan="3" style="width:102px" %)[[MSSQL>>doc:Разработка.Базы данных.SQL.MSSQL.WebHome]]|(% style="width:160px" %) |(% style="width:923px" %)14 вопросов об индексах в SQL Server, которые вы стеснялись задать
36 +14 вопросов об индексах в SQL Server, которые вы стеснялись задать
56 56  https://habr.com/ru/post/247373/
57 -|(% style="width:160px" %) |(% style="width:923px" %)Основы индексов в Microsoft SQL Server
38 +
39 +Основы индексов в Microsoft SQL Server
58 58  https://info-comp.ru/programmirovanie/575-index-basics-in-ms-sql-server.html
59 -|(% style="width:160px" %) |(% style="width:923px" %)Обслуживание индексов и статистик MS SQL Server
41 +
42 +Обслуживание индексов и статистик MS SQL Server
60 60  https://infostart.ru/public/256292/
61 -|(% style="width:102px" %) |(% style="width:160px" %) |(% style="width:923px" %)
62 -|(% style="width:102px" %)[[PostgreSQL>>doc:Разработка.Базы данных.SQL.PostgreSQL.WebHome]]|(% style="width:160px" %) |(% style="width:923px" %)
63 -|(% style="width:102px" %) |(% colspan="1" rowspan="2" style="width:160px" %)Postgres Professional|(% style="width:923px" %)Индексы в PostgreSQL — 1
64 -[[https:~~/~~/habr.com/ru/company/postgrespro/blog/326096/>>https://habr.com/ru/company/postgrespro/blog/326096/]]
65 -|(% style="width:102px" %) |(% style="width:923px" %)Индексы в PostgreSQL — 2
66 -[[https:~~/~~/habr.com/ru/company/postgrespro/blog/326106/>>https://habr.com/ru/company/postgrespro/blog/326106/]]
67 -|(% style="width:102px" %) |(% style="width:160px" %) |(% style="width:923px" %)Неожиданная находка, которая освобождает 20 GB неиспользованного индексного пространства [Postgres]
68 -https://habr.com/ru/company/otus/blog/672102/
69 69  
70 -----
71 71  
72 -(% style="width:1188px" %)
73 -|(% style="width:194px" %)Обслуживание|(% style="width:990px" %)Оценка состояния индексов. Поддержка индексов в актуальном состоянии.
74 -Критерии состояния индекса (фрагментация).
75 -Действия по обслуживанию индекса (перестроение, пересоздание).
76 -|(% style="width:194px" %)Размеры индекса|(% style="width:990px" %)Умещается ли индекс целиком в оперативной памяти
77 -|(% style="width:194px" %) |(% style="width:990px" %)Fill factor
78 -[[https:~~/~~/habr.com/ru/post/570722/>>https://habr.com/ru/post/570722/]]
79 -|(% style="width:194px" %) |(% style="width:990px" %)Дружим ORDER BY с индексами
80 -[[https:~~/~~/habr.com/ru/companies/tinkoff/articles/487412/>>https://habr.com/ru/companies/tinkoff/articles/487412/]]
81 -
82 -
46 +Неожиданная находка, которая освобождает 20 GB неиспользованного индексного пространства [Postgres]
47 +https://habr.com/ru/company/otus/blog/672102/
XWiki.XWikiComments[0]
Автор
... ... @@ -1,0 +1,1 @@
1 +XWiki.cccc1808
Комментарий
... ... @@ -1,0 +1,5 @@
1 +Кластеризованный индекс Guid или int:
2 +В случае если кластеризованный индекс является нарастающим числом, то вставка новой строки всегда будет происходит в конец существующего набора данных. (Max + 1)
3 +В случае если кластеризованный индекс является GUID, то значения индекса может попасть в любую позицию набора данных (начало/середина/конец), т.к. GUID по умолчанию не дает гарантии нарастания, что может негативно сказаться на производительности.
4 +
5 +В некоторых случаях может иметь смыл наличие двух столбцов, один из которых int, а второй guid.
Дата
... ... @@ -1,0 +1,1 @@
1 +2020-04-25 13:34:08.317