Sintomas
Suponha que você tenha um script que use notificações de evento para AUDIT_LOGIN e AUDIT_LOGIN_FAILED eventos no Microsoft SQL Server 2016 e no 2017. Ao executar o script, você notará que TempDB se torna o tamanho rápido.
Você pode usar a consulta abaixo para verificar se o espaço alocado para objetos internos TempDB está desalocado corretamente.
SELECT *
FROM (
SELECT TS.internal_objects_alloc_page_count , TS.internal_objects_dealloc_page_count, [Net Allocation MB] = CAST((TS.internal_objects_alloc_page_count - TS.internal_objects_dealloc_page_count) AS DECIMAL(15, 2)) / 128
, TS.session_id
, ER.command
FROM sys.dm_db_task_space_usage TS
INNER JOIN sys.dm_exec_requests ER ON ER.request_id = TS.request_id AND ER.session_id = TS.session_id
where TS.session_id < 50
) internal
where [Net Allocation MB] != 0
Causa
Esse problema ocorre devido a uma regressão na atualização cumulativa 6 para SQL Server 2016 Service Pack 1.
Resolução
Esse problema foi corrigido nas seguintes atualizações cumulativas do SQL Server:
Atualização cumulativa 10 para SQL Server 2017
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 terminologiaque a Microsoft usa para descrever atualizações de software.