С Новым годом! Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/48: Рейтинг темы: голосов - 48, средняя оценка - 4.60
0 / 0 / 0
Регистрация: 30.12.2013
Сообщений: 9

Добавление индекса к уже существующей таблице с данными

01.04.2014, 12:26. Показов 9460. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый ))

Есть таблица с уже 300 000 строк. Индексы отсутствуют и простой select запрос выполняется долго, решил добавить индекс по дате (Clustered тип datetime) и всё запросы выполнялись быстро. Через несколько времени заметил что запросы опять выполняются долго. Решил перестроить индекс и вуаля опять заработало и на меня дошло что каждый раз когда обновляется база то необходимо перестроить индекс.

Что я делаю не так? Как можно автоматизировать перестройку индексов?

Спасибо
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
01.04.2014, 12:26
Ответы с готовыми решениями:

Создание поля в существующей таблице и заполнение его данными
Дамы и господа, такой вопрос: Есть две таблицы, к примеру, табл1 Владельцы животных - информация о владельцах животных табл2...

Создание id в существующей таблице
Есть база на sql server 2008, в ней есть таблицы с записями но без id... Хотелось бы добавить id со значениями 1,2,3,4...Помогите...

Можно ли узнать, как устроены связи в таблицах, уже существующей базы данных в microsoft sql?
У меня задача, осознать структуру БД. Таблиц очень много, и мне для понимая, не помешала бы структура связей между ними. Можно ли...

8
 Аватар для ksk
624 / 495 / 43
Регистрация: 05.07.2010
Сообщений: 1,589
01.04.2014, 19:38
Перестройка обычно не нужна, индекс апдейтится при вставке / модификации поля.

Я обычно делаю индекс так:
SQL
1
2
3
4
5
IF NOT EXISTS (SELECT * FROM sysindexes WHERE id = object_id(N'dbo.TimeZone') AND OBJECTPROPERTY(id, N'IsTable') = 1 AND name='IX_TT') BEGIN
  PRINT 'Создаётся индекс TimeZone.IX_TT'
  CREATE INDEX IX_TT ON dbo.TimeZone(T1,T2)
END
GO
Кластерным его не обязательно делать.

Описанная вами ситуация бывает, когда на таблице есть несколько похожих индексов и оптимизатор между ними не может выбрать. В этом случае нужно либо убрать ненужный индекс, либо в запросе указывать, по какому индексу делать выборку, например:
SQL
1
2
3
SELECT T1, T2 FROM dbo.TimeZone
    WITH( INDEX (IX_TT) )
    WHERE T1 BETWEEN '15:30:05.030' AND '15:30:05.045';
0
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
01.04.2014, 21:18
Цитата Сообщение от ksk Посмотреть сообщение
Кластерным его не обязательно делать.
Как можно давать такой совет не видя ни запроса, ни DDL-таблиц?
Цитата Сообщение от ksk Посмотреть сообщение
Описанная вами ситуация бывает, когда на таблице есть несколько похожих индексов и оптимизатор между ними не может выбрать.
Можете продемонстрировать?

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
 Аватар для ksk
624 / 495 / 43
Регистрация: 05.07.2010
Сообщений: 1,589
01.04.2014, 23:05
Цитата Сообщение от invm Посмотреть сообщение
Как можно давать такой совет не видя ни запроса, ни DDL-таблиц?
Чисто из практики обращения с метками времни - они могут быть не уникальны. Но таки да, согласен.

Цитата Сообщение от invm Посмотреть сообщение
Можете продемонстрировать?
Составной индекс по одному из полей и метки времени и другой составной индекс по тем же полям плюс ещё одно поле.

Были тормоза по полторы минуты, нашёл профайлером один запрос - и сотни тысяч reads на
SELECT TOP 1 по условию равенства ID и ORDER BY метка времени DESC.

Добавил хинт, на нужный индекс указующий, результат стал приходить мгновенно и чтений единицы (не помню уже цифру).

По количеству записей - добавляется 25 строк в секунду с глубиной хранения 4 месяца.

Потом поискал запросы с использованием ненужного индекса (у меня по нему запросов не было), индекс оказался брошенным, удалили его. Хинт оставил на случай, если кто-нибудь ещё чего-нибудь добавит.
0
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
02.04.2014, 00:21
Цитата Сообщение от ksk Посмотреть сообщение
Чисто из практики обращения с метками времни - они могут быть не уникальны.
Кластерный индекс не обязательно должен быть уникальным. А вот RID/Key Lookup, вытекающая из использования некластерного, весьма дорогая операция. Если интересно, пример:
Кликните здесь для просмотра всего текста
T-SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
use tempdb;
go
 
create table dbo.t (id int not null, v int null);
go
 
insert into dbo.t
select top (10000)
 row_number() over (order by char('a')),
 1
from
 master.dbo.spt_values a cross join
 master.dbo.spt_values b;
go
 
create clustered index IX_t__id on dbo.t (id);
go
 
set statistics xml, io on;
select count(v) from dbo.t where id between 1 and 2000;
set statistics xml, io off;
go
 
drop index dbo.t.IX_t__id;
create index IX_t__id on dbo.t (id);
go
 
set statistics xml, io on;
select count(v) from dbo.t where id between 1 and 2000;
set statistics xml, io off;
go
 
set statistics xml, io on;
select count(v) from dbo.t with (index = IX_t__id) where id between 1 and 2000;
set statistics xml, io off;
go
 
drop table dbo.t;
go
Обратите внимание на количество чтений.

Цитата Сообщение от ksk Посмотреть сообщение
Составной индекс по одному из полей и метки времени и другой составной индекс по тем же полям плюс ещё одно поле.
Были тормоза по полторы минуты, нашёл профайлером один запрос - и сотни тысяч reads на
SELECT TOP 1 по условию равенства ID и ORDER BY метка времени DESC.
Вы, наверное, что-то путаете или забыли как было дело. Для приведенного запроса подойдут индексы по (ID, [метка времени], ...), либо по ([метка времени], ...), но не (..., [метка времени], ...).Конечно, оптимизатор может промахнуться с выбором плана и индекса, особенно если статистика неактуальна. Но к ситуации ТС'а это не относится - у него индекс один.
1
0 / 0 / 0
Регистрация: 30.12.2013
Сообщений: 9
02.04.2014, 10:22  [ТС]
Совсем запутался... изменение в базу уже были а запросы быстрые значит причина в другом

Добавлено через 1 час 21 минуту
Теперь запросы идут медленно можно тестить.

Пробовал WITH( INDEX (IX_DATE) ) результата нет (
0
 Аватар для ksk
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
Цитата Сообщение от ksk Посмотреть сообщение
Доживу до выходного - попрофилирую. Со статистиками не работал ни разу.
Не надо ничего профилировать - просто выполнить скрипт: планы будут в результатах, статистика IO на вкладке Messages.
Цитата Сообщение от ksk Посмотреть сообщение
Единственное, что я бы тут сделал - профайлером бы посмотрел, какие запросы ОРМ реально отправляет серверу, какие получчабтся накладные расходы. Спринтскринил бы план выполнения запроса, и уже показывая эту информацию задавал бы вопросы специалистам по SQL. Может тормоза вообще не в SQL, а в ентитях коренятся.
+1
Только планы не принтскринить, а сохранять в файлы формата sqlplan.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
02.04.2014, 20:15
Помогаю со студенческими работами здесь

Как создать ячейку в уже существующей таблице
Извеняюсь за такой глупый вопрос, но как создать ячейку в уже существующей таблице? Т.е есь таблица с названием news в ней есть ячейки: id,...

Создание записей в таблице на основе данных уже существующей таблицы
Добрый день! Данные вводимые в базу можно условно разделить на 2 части: Основные данные(неизменные от раза к разу) и уточняющие(меняются...

Запрос на добавление новой строки к уже существующей
Всем привет! Есть таблица с полем, у которого есть строка с данными. Не могу составить SQL-запрос для добавления данных к содержимому...

Добавление почты скриптом к уже существующей учетной записи в AD
Всем привет. Надо добавить более 100 адресов электронной почты пользователям в AD чьи учетки уже заведены. Кто подскажет, как можно это...

Запрет дублирования уже существующей записи в таблице по "поле1" вводимым из формы?
Уважаемые форумчане? Подскажите, как запретить создание новой записи в форме при условии уже существующей аналогичной. При этом поле в...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Новый 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-динозавры, а новое поколение лёгких потоков. Откат?. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru