Логотип YeaHub

База вопросов

Собеседования

Тренажёр

База ресурсов

Обучение

Навыки

Войти

Выбери, каким будет IT завтра — вместе c нами!

YeaHub — это полностью открытый проект, призванный объединить и улучшить IT-сферу. Наш исходный код доступен для просмотра на GitHub. Дизайн проекта также открыт для ознакомления в Figma.

© 2026 YeaHub

Документы

Медиа

Назад

Почему массовые операции в MS SQL требуют перестроения индексов?

Проверяет понимание влияния массовых операций на индексы.

Короткий ответ

Массовые операции:

  1. Нарушают физический порядок данных

  2. Увеличивают фрагментацию индексов

  3. Снижают эффективность B-деревьев

  4. Ухудшают статистику для оптимизатора

Длинный ответ

Проблемы массовых операций:

  1. Фрагментация страниц

    -- До операции
    Страница 1: [1][2][3][4][5]
    -- После DELETE + INSERT
    Страница 1: [1][NULL][3][NULL][5]
  2. Устаревшая статистика
    Оптимизатор не знает о новых данных:

    UPDATE STATISTICS Orders WITH FULLSCAN;
  3. Решения:

    • Перестроение индексов (ALTER INDEX REBUILD)

    • Использование SORT_IN_TEMPDB

    • Оптимизация fillfactor

Пример перестроения:

-- После массовой вставки
ALTER INDEX ALL ON Orders REBUILD 
WITH (ONLINE = ON, SORT_IN_TEMPDB = ON);

Уровень

  • Рейтинг:

    1

  • Сложность:

    6

Навыки

  • MSSQL

Ключевые слова

#index maintenance

#fragmentation

#bulk operations

Подпишись на C# Developer в телеграм