Создание индексированных просмотров
-
25-09-2019 - |
Вопрос
Когда я пытаюсь создать проиндексированное представление, я получаю ошибку «DATYPART возвращает неопределенное значение, используйте систему определенной детерминированной функции или сделать функцию определенной пользовательской функцией для возврата детерминированного значения», «я получаю эту ошибку, когда я пытаюсь создать индекс на виду ..
Запрос есть
CREATE VIEW dbo.two_weeks_performance WITH SCHEMABINDING
as
SELECT dbo.day_dim.date_time AS Date, dbo.order_dim.quantity AS Target_Acheived
FROM dbo.day_dim
JOIN dbo.order_fact ON dbo.day_dim.day_id = dbo.order_fact.day_id
JOIN dbo.branch_dim ON dbo.order_fact.branch_id = dbo.branch_dim.branch_id
JOIN dbo.order_dim ON dbo.order_fact.order_id = dbo.order_dim.order_id
WHERE (DATEPART(wk, CONVERT(datetime, dbo.day_dim.date_time, 101)) <= DATEPART(wk, GETDATE() - 2))
GROUP BY dbo.order_dim.quantity, dbo.day_dim.date_time
GO
CREATE UNIQUE CLUSTERED INDEX two_weeks_performance_I on two_weeks_performance (Date,Target_Acheived)`
В этой дате date_ varchar (30) тип. Дайте мне решение поступить в эту проблему.
Решение
Использовать:
CREATE VIEW dbo.two_weeks_performance WITH SCHEMABINDING
AS
SELECT dbo.day_dim.date_time AS Date,
dbo.order_dim.quantity AS Target_Acheived
FROM dbo.day_dim
JOIN dbo.order_fact ON dbo.day_dim.day_id = dbo.order_fact.day_id
JOIN dbo.branch_dim ON dbo.order_fact.branch_id = dbo.branch_dim.branch_id
JOIN dbo.order_dim ON dbo.order_fact.order_id = dbo.order_dim.order_id
GROUP BY dbo.order_dim.quantity, dbo.day_dim.date_time
Проблема была использование GetDate (); Это не детерминированное, возвращая другое значение каждый раз.
Так что вам придется использовать:
SELECT t.*
FROM dbo.two_weeks_performance t
WHERE DATEPART(wk, CONVERT(datetime, t.date, 101)) <= DATEPART(wk, GETDATE() - 2)
Не связан с StackOverflow