Новые сообщения [новые:0]
Дайджест
Горячие темы
Избранное [новые:0]
Форумы
Пользователи
Статистика
Статистика нагрузки
Мод. лог
Поиск
|
10.08.2020, 16:05
|
|||
---|---|---|---|
|
|||
Поведение оптимизатора |
|||
#18+
Товарищи, здравствуйте. Существует две таблицы: 1. Analytic (nRec : binary(8)) nonclustered index on nRec unique; 2. AnSets (nRec : binary(8), cAnalyt : binary(8), set_name varchar(255)) nonclustered index on cAnalyt + set_name + nRec unique; В первой таблице ~3к записей, во второй ~8к. У второй таблы есть статистика по полям cAnalyt + set_name + nRec Строю запрос: Код: sql 1.
Получаю ожидаемый план выполнения - IndexSeek и вывод. При этом автоматически создается системная статистика _wa_sys_set_name _AnSets Строю второй запрос Код: sql 1.
Вместо IndexSeek для AnSets получаю IndexScan и предложение создать некластерный индекс set_name + cAnalyt. Прошу помочь разобраться, почему так и куда можно посмотреть. MS Sql server 2017 ... |
|||
:
Нравится:
Не нравится:
|
|||
|
10.08.2020, 16:31
|
|||
---|---|---|---|
Поведение оптимизатора |
|||
#18+
Напишите Код: sql 1.
И получите искомый seek. Затем сравните по стоимости с исходным запросом и поймете почему оптимизатор не выбрал NL. ... |
|||
:
Нравится:
Не нравится:
|
|||
|
|
start [/forum/topic.php?fid=46&mobile=1&tid=1685791]: |
0ms |
get settings: |
6ms |
get forum list: |
11ms |
check forum access: |
2ms |
check topic access: |
2ms |
track hit: |
24ms |
get topic data: |
10ms |
get forum data: |
2ms |
get page messages: |
38ms |
get tp. blocked users: |
1ms |
others: | 15ms |
total: | 111ms |
0 / 0 |