"Закладка" - це оригінальний локатор індексу стовпців (за "Внутрішньою програмою SQL Server" Дмитра Короткевича). Це 8-байтове значення з індексом зберігання стовпців row_group_id
у перших 4- байтних та зсувом у другому 4-байтних.
Якщо ви DBCC PAGE
шукаєте некластеризований індекс, 8-байтовий локатор індексу зберігання стовпців з'являється в стовпці "Уніфікатор" DBCC PAGE
виводу. Це показує, що унікальному некластеризованому індексу не потрібно включати локатор рядків стовпців, тоді як не унікальний некластеризований індекс.
Наступний код створює організовану стовпчиком таблицю з унікальним і не унікальним індексом некластеризованого b-дерева в тому ж стовпці:
CREATE TABLE dbo.Heapish
(
c1 bigint NOT NULL,
c2 bigint NOT NULL,
INDEX CCI_dbo_Heapish CLUSTERED COLUMNSTORE
);
GO
INSERT dbo.Heapish WITH (TABLOCKX)
(c1, c2)
SELECT TOP (1024 * 1024 * 8)
c1 = ROW_NUMBER() OVER
(ORDER BY C1.[object_id], C1.column_id),
c2 = ROW_NUMBER() OVER
(ORDER BY C1.[object_id], C1.column_id)
FROM master.sys.columns AS C1
CROSS JOIN master.sys.columns AS C2
ORDER BY
c1
OPTION (MAXDOP 1);
GO
CREATE UNIQUE NONCLUSTERED INDEX UNIQUE_c2 ON dbo.Heapish (c2) WITH (MAXDOP = 1);
CREATE NONCLUSTERED INDEX NONUNIQUE_c2 ON dbo.Heapish (c2) WITH (MAXDOP = 1);
Ми можемо бачити розмір рядка індексу на різних рівнях b-дерева, використовуючи sys.dm_db_index_physical_stats
:
SELECT
DDIPS.index_level,
DDIPS.page_count,
DDIPS.record_count,
DDIPS.min_record_size_in_bytes,
DDIPS.max_record_size_in_bytes
FROM sys.dm_db_index_physical_stats
(
DB_ID(),
OBJECT_ID(N'dbo.Heapish', N'U'),
INDEXPROPERTY(OBJECT_ID(N'dbo.Heapish', N'U'), N'UNIQUE_c2', 'IndexID'),
NULL, 'DETAILED'
) AS DDIPS;
SELECT
DDIPS.index_level,
DDIPS.page_count,
DDIPS.record_count,
DDIPS.min_record_size_in_bytes,
DDIPS.max_record_size_in_bytes
FROM sys.dm_db_index_physical_stats
(
DB_ID(),
OBJECT_ID(N'dbo.Heapish', N'U'),
INDEXPROPERTY(OBJECT_ID(N'dbo.Heapish', N'U'), N'NONUNIQUE_c2', 'IndexID'),
NULL, 'DETAILED'
) AS DDIPS;
Вихід:
Обидві структури мають однаковий розмір рядків на рівні аркуша, але нереалізований некластеризований індекс на 12 байт більший за унікальний некластеризований індекс на нелистових рівнях завдяки 8-байтовому локатору стовпців, плюс 4 байти накладних даних для першої змінної стовпчик довжини в рядку (уніфікатор змінної довжини).