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

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

<
От версии < 11.5 >
отредактировано Alexandr Fokin
на 2024/03/24 14:37
К версии < 7.6 >
отредактировано Alexandr Fokin
на 2022/11/25 17:31
>
Изменить комментарий: Update document after refactoring.

Комментарий

Подробности

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