|
0 / 0 / 0
Регистрация: 30.12.2013
Сообщений: 9
|
|
Добавление индекса к уже существующей таблице с данными01.04.2014, 12:26. Показов 9460. Ответов 8
Метки нет (Все метки)
Добрый ))
Есть таблица с уже 300 000 строк. Индексы отсутствуют и простой select запрос выполняется долго, решил добавить индекс по дате (Clustered тип datetime) и всё запросы выполнялись быстро. Через несколько времени заметил что запросы опять выполняются долго. Решил перестроить индекс и вуаля опять заработало и на меня дошло что каждый раз когда обновляется база то необходимо перестроить индекс. Что я делаю не так? Как можно автоматизировать перестройку индексов? Спасибо
0
|
|
| 01.04.2014, 12:26 | |
|
Ответы с готовыми решениями:
8
Создание поля в существующей таблице и заполнение его данными Создание id в существующей таблице Можно ли узнать, как устроены связи в таблицах, уже существующей базы данных в microsoft sql? |
|
624 / 495 / 43
Регистрация: 05.07.2010
Сообщений: 1,589
|
|||||||||||
| 01.04.2014, 19:38 | |||||||||||
|
Перестройка обычно не нужна, индекс апдейтится при вставке / модификации поля.
Я обычно делаю индекс так:
Описанная вами ситуация бывает, когда на таблице есть несколько похожих индексов и оптимизатор между ними не может выбрать. В этом случае нужно либо убрать ненужный индекс, либо в запросе указывать, по какому индексу делать выборку, например:
0
|
|||||||||||
|
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
|
|||
| 01.04.2014, 21:18 | |||
|
UNGVAS, вы лучше актуальные планы выполнения покажите (в формате sqlplan) для медленного и быстрого вариантов.
0
|
|||
|
0 / 0 / 0
Регистрация: 30.12.2013
Сообщений: 9
|
|
| 01.04.2014, 22:27 [ТС] | |
|
Ещё замечание: я использую Entity Framework и запросы выполняются долго только в приложении но если перестрою индекс то выполняется быстро.
Когда индекса небыло то обычный запрос выполнялся долго и в SQL management studio и в WebApi но после того как добавил индекс то в SQL management studio запрос выполняется быстро уже всегда но в приложении нужно переодически перестроить индекс Спасибо за советы поппробую завтра и отпишусь ))
0
|
|
|
624 / 495 / 43
Регистрация: 05.07.2010
Сообщений: 1,589
|
|||
| 01.04.2014, 23:05 | |||
|
Были тормоза по полторы минуты, нашёл профайлером один запрос - и сотни тысяч reads на SELECT TOP 1 по условию равенства ID и ORDER BY метка времени DESC. Добавил хинт, на нужный индекс указующий, результат стал приходить мгновенно и чтений единицы (не помню уже цифру). По количеству записей - добавляется 25 строк в секунду с глубиной хранения 4 месяца. Потом поискал запросы с использованием ненужного индекса (у меня по нему запросов не было), индекс оказался брошенным, удалили его. Хинт оставил на случай, если кто-нибудь ещё чего-нибудь добавит.
0
|
|||
|
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
|
||||||||
| 02.04.2014, 00:21 | ||||||||
|
Кликните здесь для просмотра всего текста
1
|
||||||||
|
0 / 0 / 0
Регистрация: 30.12.2013
Сообщений: 9
|
|
| 02.04.2014, 10:22 [ТС] | |
|
Совсем запутался... изменение в базу уже были а запросы быстрые значит причина в другом
Добавлено через 1 час 21 минуту Теперь запросы идут медленно можно тестить. Пробовал WITH( INDEX (IX_DATE) ) результата нет (
0
|
|
|
624 / 495 / 43
Регистрация: 05.07.2010
Сообщений: 1,589
|
|
| 02.04.2014, 18:52 | |
|
invm, спасибо. Конечно, интересно. Доживу до выходного - попрофилирую. Со статистиками не работал ни разу.
Возможно, я не вполне помню, как было дело, так запомнилось. Было такое: (ID, [метка времени], ...), либо по ([метка времени], ...), при указании в хинте на второй вариант всё прошло. И у меня всё ещё есть подозрение, что мы не можем точно знать, сколько у ТС индексов, пока он их явным образом не посчитает ) UNGVAS, если у Вас Ентить, то я отойду в тень, ибо это не моя поляна. Возможно, не в SQL части дело, а в том, как ОРМ готовит запросы. Единственное, что я бы тут сделал - профайлером бы посмотрел, какие запросы ОРМ реально отправляет серверу, какие получчабтся накладные расходы. Спринтскринил бы план выполнения запроса, и уже показывая эту информацию задавал бы вопросы специалистам по SQL. Может тормоза вообще не в SQL, а в ентитях коренятся.
0
|
|
|
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
|
|||
| 02.04.2014, 20:15 | |||
|
Только планы не принтскринить, а сохранять в файлы формата sqlplan.
1
|
|||
| 02.04.2014, 20:15 | |
|
Помогаю со студенческими работами здесь
9
Как создать ячейку в уже существующей таблице
Запрос на добавление новой строки к уже существующей Добавление почты скриптом к уже существующей учетной записи в AD Запрет дублирования уже существующей записи в таблице по "поле1" вводимым из формы? Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
|
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение.
И на уровне агентов добавится между грибами или бактериями взаимодействий.
До того я пробовал подход через многомерные массивы,. . .
|
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Налог на собак: https:/ / **********/ gallery/ V06K53e
Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf
Пост отсюда. . .
|
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop?
Ниже её машинный перевод.
После долгих разбирательств я наконец-то вернула себе. . .
|
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод
Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод.
Thinkpad X220 Tablet —. . .
|
|
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта
Симптом:
После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
|
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
|
Новый ноутбук
volvo 07.12.2025
Всем привет.
По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне:
Ryzen 5 7533HS
64 Gb DDR5
1Tb NVMe
16" Full HD Display
Win11 Pro
|
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
|
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
|