Sintomas
Considere o seguinte cenário:
-
Você tem uma consulta que contém um predicado que envolve uma função escalar parametrizada definida pelo usuário.
-
Há várias combinações de valores de parâmetros de entrada que podem produzir o mesmo resultado por essa função definida pelo usuário.
-
O SQL Server usa o novo estimador de cardinalidade no qual o modo de compatibilidade de banco de dados é definido como 120.
Nesse cenário, quando você executa a consulta, você experimenta um desempenho de consulta ruim porque um número estimado de linhas incorretamente para o predicado envolve a função definida pelo usuário no plano de consulta.
Resolução
Este problema foi corrigido primeiro na seguinte atualização cumulativa do SQL Server:
Atualização cumulativa 6 para SQL Server 2014 Service Pack 1Depois de instalar esse pacote de atualização cumulativa, você precisa habilitar o sinalizador de rastreamento 4199. Para fazer isso, você pode adicionar o parâmetro de inicialização -T4199 . Ou, você pode usar a instrução DBCC Traceing (4199) para uma sessão específica.
Cada nova atualização cumulativa do SQL Server contém todos os hotfixes e todas as correções de segurança incluídas na atualização cumulativa anterior. Confira as atualizações cumulativas mais recentes do SQL Server:
Status
A Microsoft confirmou que este é um problema nos produtos Microsoft listados na seção "Aplicável a".
Referências
Saiba mais sobre a terminologia usada pela Microsoft para descrever atualizações de software.