Симптоми
Когато SQL планът е с активирано взаимно изпълнение и използва клаузата OPTION (OPTIMIZE FOR), функцията TVF( с таблична стойност), която използва параметър, подаден в същата SQL команда, дава неправилни резултати при първото изпълнение.
Решение
Този проблем е решен в следната кумулативна актуализация за SQL Server:
Кумулативна актуализация 19 за SQL Server 2019 г.
Забележка Ето пример за неуспешно изпълнение, след като инсталирате тази кумулативна актуализация:
DECLARE @start smalldatetime
SELECT count(*) FROM dbo.GetData(@start)
OPTION (OPTIMIZE FOR (@start = '2022-05-23T06:00:00'))
CREATE FUNCTION [dbo].[GetData]
(
@start datetime
)
RETURNS TABLE AS RETURN
SELECT t.id FROM dbo.TestTable t
WHERE t.testdate >= @start
GO
CREATE TABLE [dbo].[TestTable](
[id] [int] IDENTITY(1,1) NOT NULL,
[testdate] [datetime] NULL
) ON [PRIMARY]
GO
Всяка нова кумулативна актуализация за SQL Server съдържа всички горещи поправки и корекции на защитата, които са били в предишната компилация. Препоръчваме ви да инсталирате най-новата компилация за вашата версия на SQL Server:
Статут
Microsoft потвърди, че това е проблем в продуктите на Microsoft, които са изброени в раздела "Отнася се за".
Препратки
Научете повече за терминологията, която Microsoft използва за описване на актуализациите на софтуера.