Как создать отфильтрованный индекс с NOT IN в SQL Server - PullRequest
0 голосов
/ 12 декабря 2018

Я хочу создать УНИКАЛЬНЫЙ НЕКЛАСТЕРНЫЙ ИНДЕКС, который ограничивает некоторые записи для определенного столбца, который я использую NOT IN, чтобы отфильтровать его, но я получаю ошибку из-за NOT IN.какая альтернатива это сделать?

CREATE UNIQUE NONCLUSTERED INDEX 
[UN_Student] ON [dbo].[Student]
(
[School_Cd] ASC,
[Class_Id] ASC,
[Enroll_Dt] ASC,
[Email_Id] ASC
)
WHERE ([School_Cd]='EM' AND [Class_Id] NOT IN (1,2,3))
WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, SORT_IN_TEMPDB = OFF, 
IGNORE_DUP_KEY = OFF, DROP_EXISTING = OFF, ONLINE = OFF, ALLOW_ROW_LOCKS = 
ON, ALLOW_PAGE_LOCKS = ON)

Ответы [ 2 ]

0 голосов
/ 12 декабря 2018

Отфильтрованные индексы не могут использовать NOT IN.Вместо этого вы можете использовать несколько AND операторов.У Брента Озара есть очень хорошая статья здесь о том, что разрешено и что не разрешено для отфильтрованных индексов.

CREATE UNIQUE NONCLUSTERED INDEX 
[UN_Student] ON [dbo].[Student]
(
[School_Cd] ASC,
[Class_Id] ASC,
[Enroll_Dt] ASC,
[Email_Id] ASC
)
WHERE ([School_Cd]='EM' AND [Class_Id] <> 1 AND [Class_Id] <> 2 AND [Class_Id] <> 3)
WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, SORT_IN_TEMPDB = OFF, 
IGNORE_DUP_KEY = OFF, DROP_EXISTING = OFF, ONLINE = OFF, ALLOW_ROW_LOCKS = 
ON, ALLOW_PAGE_LOCKS = ON)
0 голосов
/ 12 декабря 2018
..WHERE ([School_Cd]='EM' AND ([Class_Id] <> 1 AND [Class_Id] <> 2 AND [Class_Id] <> 3))
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...