Eu quero ter uma pesquisa rápida com base em se duas colunas são iguais. Tentei usar uma coluna computada com um índice, mas o SQL Server não parece usá-lo. Se eu apenas usar uma coluna de bits preenchida estaticamente com um índice, recebo a busca de índice esperada.
Parece que existem outras perguntas como essa, mas nenhuma se concentrou no motivo pelo qual um índice não seria usado.
Tabela de teste:
CREATE TABLE dbo.Diffs
(
Id int NOT NULL IDENTITY (1, 1),
DataA int NULL,
DataB int NULL,
DiffPersisted AS isnull(convert(bit, case when [DataA] is null and [DataB] is not null then 1 when [DataA] <> [DataB] then 1 else 0 end), 0) PERSISTED ,
DiffComp AS isnull(convert(bit, case when [DataA] is null and [DataB] is not null then 1 when [DataA] <> [DataB] then 1 else 0 end), 0),
DiffStatic bit not null,
Primary Key (Id)
)
create index ix_DiffPersisted on Diffs (DiffPersisted)
create index ix_DiffComp on Diffs (DiffComp)
create index ix_DiffStatic on Diffs (DiffStatic)
E a consulta:
select Id from Diffs where DiffPersisted = 1
select Id from Diffs where DiffComp = 1
select Id from Diffs where DiffStatic = 1
COALESCE
neste momento; Acredito que aCASE
instrução já estava garantida para retornar0
ou1
, masISNULL
estava presente apenas para que o SQL Server produzisse um valor nuloBIT
para a coluna computada. No entanto,COALESCE
ainda produzirá uma coluna anulável. Portanto, o único impacto dessa alteração, com ou sem oCOALESCE
, é que a coluna computada agora é anulável, mas a busca do índice pode ser usada.