Sintomas
Suponha que você habilite o recurso CDC (Captura de Dados de Alteração) em uma tabela para executar uma verificação de log no Microsoft SQL Server. O parâmetro pollinginterval é convertido de segundos (s) para horas (h) no procedimento armazenado sys.sp_cdc_scan . No entanto, quando o parâmetro pollinginterval for maior que uma hora (>3600 s), você perceberá que o resultado convertido está incorreto.
declare @pollinginterval bigint, @seconds bigint, @minutes bigint, @hours bigint
set @pollinginterval = 3600
selecione @seconds = @pollinginterval % 60
selecione @minutes = ((@pollinginterval - @seconds) / 60) % 60
selecione @hours = (@pollinginterval - (@minutes * 60) - @seconds) / 60
--- Próxima tentativa abaixo da linha em vez disso
--- selecione @hours = (@pollinginterval - (@minutes * 60) - @seconds) / 60 /60
selecione @hours, @minutes, @seconds
Resolução
Esse problema é corrigido nas seguintes atualizações cumulativas para SQL Server:
Atualização cumulativa 12 para SQL Server 2017
Atualização cumulativa 3 para SQL Server 2016 SP2
Atualização cumulativa 12 para SQL Server 2016 SP1
Cada nova atualização cumulativa para SQL Server contém todos os hotfixes e todas as correções de segurança incluídas na atualização cumulativa anterior. Confira as últimas atualizações cumulativas para SQL Server:
Atualização cumulativa mais recente para SQL Server 2017
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.