Фактический план выполнения не обновляется после изменения хранимой процедуры базы данных Azure SQL

В фактическом плане выполнения моей хранимой процедуры базы данных Azure SQL указано следующее предупреждение:

введите описание изображения здесь

Итак, я пошел и добавил постоянный вычисленный столбец в dbo.Interest_rate_changes вот так:

[Effective_date]  AS (CONVERT([date],CONVERT([nchar](8),[Effective_date_int]),(112))) PERSISTED NOT NULL

Затем я заменил все ссылки на Interest_date_int в хранимой процедуре со ссылками на Interest_date.

Я снова выполнил запрос, но в фактическом плане выполнения появилось такое же предупреждение, даже если в хранимой процедуре не существует ссылки на Effective_date_int.

Я попытался очистить кеш с помощью DBCC FREEPROCCACHE, но база данных Azure SQL этого не позволит.

Что я делаю неправильно?

В ответ на комментарии фактический план выполнения находится здесь.

Запрос таков:

EXEC TEST_PopulateCachedDailyInterest 11,'2017-12-31'

Хранимая процедура - это (извинения, что я не профессионал):

CREATE PROCEDURE [dbo].[TEST_PopulateCachedDailyInterest] (@entityid int = 0, @enddate date)
AS

SET NOCOUNT ON;

TRUNCATE TABLE TEST_CachedDailyInterest;

WITH A AS
(
SELECT
    MyEntity AS Entity,
    MyInstrument AS Instrument,
    Accrual_date AS AccrualDate,
    Balance_x_Par_value_x_Effective_rate AS AccrualNumerator,
    Yearfrac_reciprocal AS AccrualDenominator

FROM

(SELECT
    MyEntity,
    MyInstrument,
    Instrument_currency,
    Interest_convention,
    Yearfrac_date_shift,
    Calendar_date AS Accrual_date,
    (SELECT SUM(Units) FROM Unit_transactions_indexed WITH (NOEXPAND) WHERE Entity = MyEntity AND Instrument = MyInstrument AND DATEADD(day,Opening_balance_date_shift,Transaction_date) < Calendar_date) * Par_value *
    (SELECT TOP 1 Interest_rate  FROM Interest_rate_changes WHERE Instrument = MyInstrument AND DATEADD(day,Interest_date_shift, Effective_date) <= Calendar_date ORDER BY Effective_date DESC) AS Balance_x_Par_value_x_Effective_rate

FROM

(SELECT  MyEntity, MyInstrument, Min_date, Max_date, Opening_balance_date_shift, Interest_date_shift, Interest_convention, Yearfrac_date_shift, Par_value, Instrument_currency FROM
(SELECT MyEntity, MyInstrument, DATEADD(day,-3,MIN(Transaction_date)) AS Min_date, IIF(SUM(Units)<>0, @enddate, IIF(DATEADD(day,3,MAX(Transaction_date))>[email protected], @enddate, DATEADD(day,3,MAX(Transaction_date)))) AS Max_date
FROM
(SELECT MyEntity, MyInstrument, Transaction_date, Units FROM
(SELECT Entity AS MyEntity, Instrument AS MyInstrument, Transaction_date, Units FROM Unit_transactions_indexed WITH (NOEXPAND)
WHERE Entity = @entityid AND Units <> 0 AND Units IS NOT NULL) AS A
INNER JOIN
(SELECT ID FROM Instruments WHERE Interest_type>0)  B
ON  A.MyInstrument = B.ID) C
GROUP BY MyEntity, MyInstrument)  D
INNER JOIN Instruments ON D.MyInstrument = Instruments.ID
INNER JOIN Interest_types ON Interest_type = Interest_types.ID) AS D

CROSS JOIN Calendar_dates WHERE Calendar_date BETWEEN Min_date AND Max_date) AS F

INNER JOIN Yearfracs_reciprocal WITH (NOEXPAND) ON Balance_x_Par_value_x_Effective_rate<>0 AND
            Balance_x_Par_value_x_Effective_rate IS NOT NULL AND
            Yearfrac_reciprocal IS NOT NULL AND
            DATEADD(day,-F.Yearfrac_date_shift,F.Accrual_date) = Yearfracs_reciprocal.Calendar_date AND
            Interest_convention = Convention_ID
)

INSERT INTO TEST_CachedDailyInterest
SELECT
Entity AS EntityId,
Instrument AS InstrumentId,
AccrualDate,
AccrualNumerator,
AccrualDenominator
FROM A
WHERE ISNULL(AccrualNumerator,0)<>0

Схема таблицы для dbo.Interest_rate_changes такова:

CREATE TABLE [dbo].[Interest_rate_changes](
    [Instrument] [int] NOT NULL,
    [Effective_date_int] [int] NOT NULL,
    [Interest_rate] [decimal](9, 7) NOT NULL,
    [Effective_date]  AS (CONVERT([date],CONVERT([nchar](8),[Effective_date_int]),(112))) PERSISTED NOT NULL,
 CONSTRAINT [PK_Instrument_Date] PRIMARY KEY CLUSTERED 
(
    [Instrument] ASC,
    [Effective_date] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON)
)