72 похожих чатов

Добрый день. Вопрос про оптимизацию запросов в MS SQL 2017.

Подскажите, пожалуйста, какие индексы лучше сделать на таблицу T, в которой есть поле date (дата, по ней таблица секционирована), поле id (автоинкремент, по нему идёт связка с другими таблицами) и другие несущественные поля. Почти все запросы такого вида: select ... from T inner join T1 on T.id = T1.id where T.date between '2021-08-01' and '2021-08-31'. В кластерном индексе обязательно должно быть поле с датой, раз по нему секционирована таблица. А вот с полем id не понятно, что делать. Тоже добавить в кластерный индекс или лучше создать первичный ключ (некластерный)? Или оба варианта сразу?)

3 ответов

12 просмотров

За месяц сколько записей? И Сколько всего?

Олег-Нехлюдов Автор вопроса

Сейчас индексы такие: кластерный уникальный по date + id; primary key nonclustered id. Но мне не нравится производительность( За месяц 12 млн строк, всего в таблице 380 млн строк

Предлагаю создавать на тесте разные и смотреть на планы и статистику. Но в теории индексы должны быть максимально узкие и участвовать в фильтрации. Если ничего не путаю 🤪

Похожие вопросы

Обсуждают сегодня

Я не понимаю, это троллинг или что? Швабрика поддерживают, который буквально пишет на ассемблере взаимодействия с винапи. Я это ещё написал загрузчик и хоть что-то изучаю в о...
Shadow Akira
6
А какие существуют способы обработки ошибок выделения памяти в ядре? Т.е., допустим, есть функция, которая возвращает адрес свободной страницы в физической памяти и диапазон в...
disba1ancer
51
Всем привет. Хотел бы написать для себя свою ос. Причины: 1) нужен опыт в чем-то 2) будет меньше весить 3) свое, но там будут свои задумки Я понимаю что нужно писать для всег...
Shadow Akira
18
Привет, такой вопросик появился кажется ли вам что Rust слишком сложный/строгий для высокоуровневого программирования и слишком "безопасный"/строгий для низкоуровневого?
Крокант
10
Всем привет! Скажите, никто не пытался уменьшить размер процесса ssl, которые ассоциируется с открытым соединением (не помню точное название этого процесса, но там была какая-...
Алексей
20
Это переведённый текст с английского. Я не говорю на русском, но могу использовать переводчик Телеграм. Приветствую! Я начинающий веб-разработчик и все еще учусь. В настояще...
𐩱𐩪𐩣𐩱𐩲𐩺𐩡
3
Ребята, всем привет. Подскажите, пожалуйста, можно ли как-то через бота понять, что этого бота добавили в группу\канал и выдали ему права администратора?
Artem Stormageddon
9
Ночной вопрос остался в силе. Кто-нибудь может подсказать как preview fields расширить в Rainlab.User?
Даниил
3
А не хотим ли мы развлечься? 😉 Но так чтобы с пользой для наших профессиональных навыков?? 👨‍🎓👩‍🎓 Предлагаю на октябрь запланировать тестовый запуск новой командной игры "Игр...
Andrii Kurdiumov
2
Парни, а как можно показывать поля формы с одинаковым неймингом в бекенде в зависимости от разрешений, попробовал выставить permissions, но ругается на duplicate key. Может мо...
Racoon Mitya
1
Карта сайта