|
0 / 0 / 0
Регистрация: 30.12.2013
Сообщений: 9
|
|
Добавление индекса к уже существующей таблице с данными01.04.2014, 12:26. Показов 9556. Ответов 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" вводимым из формы? Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии.
. . .
|
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2.
При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
|
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут.
https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc
Первый документ красиво выглядит, но без схемы.
Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
|
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере".
Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
|
|
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти".
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2.
В качестве источника данных. . .
|
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер
Написал заготовку:
dotnet new console --aot -o UrlHandler
var items = args. Split(":");
var tag = items;
var id = items;
var executable = args;. . .
|
Отправка уведомления на почту при создании или изменении элементов справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере типового справочника "Склады" в конфигурации БП3.
Перед реализацией необходимо выполнить настройку системной учетной записи электронной. . .
|
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений.
9TO2GP2bpX4
a42b81fb172ffc12ca589c7898261ccb/
https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/
Слева синяя линия -. . .
|