Как делают я “Объявляю скалярную переменную” в ПРЕДСТАВЛЕНИИ в SQL-сервере (2005)

Я пытаюсь создать ПРЕДСТАВЛЕНИЕ в SQL Server 2005.

Код SQL работает как таковой (я использую его в VS2008), но в SQL Server я не могу сохранить его, поскольку сообщение об ошибке "Объявляет, что скалярная переменная @StartDate" и "Объявляет, что скалярная переменная @EndDate" открывается.

Вот код:

WITH Calendar AS (SELECT     CAST(@StartDate AS datetime) AS Date
     UNION ALL
     SELECT     DATEADD(d, 1, Date) AS Expr1
     FROM         Calendar AS Calendar_1
     WHERE     (DATEADD(d, 1, Date) < @EndDate))
    SELECT     C.Date, C2.Country, COALESCE (SUM(R.[Amount of people per day needed]), 0) AS [Allocated testers]
     FROM         Calendar AS C CROSS JOIN
                            dbo.Country AS C2 LEFT OUTER JOIN
                            dbo.Requests AS R ON C.Date BETWEEN R.[Start date] AND R.[End date] AND R.CountryID = C2.CountryID
     GROUP BY C.Date, C2.Country

И мой вопрос, конечно - точно, как я должен объявить их?

Я пытался поместить следующий сначала в код:

DECLARE @StartDate smalldatetime
DECLARE @EndDate smalldatetime

Но это не добивалось цели, как я ожидал - это только дало мне другое всплывающее сообщение:

"Объявить курсор конструкция SQL или оператор не поддерживается".

11
задан Jack Johnstone 13 August 2010 в 09:49
поделиться

2 ответа

Как упоминал Alex K, вы должны написать его как встроенную функцию с табличным значением. Вот статья , которая описывает это.

Короче говоря, синтаксис будет примерно таким:

CREATE FUNCTION dbo.GetForPeriod
    ( @StartDate datetime, @EndDate datetime) 
RETURNS TABLE 
RETURN 
   SELECT  [[ your column list ]]
   FROM    [[ table list]
   WHERE   [[some column] BETWEEN @StartDate AND @EndDate

У вас может быть один запрос выбора (каким бы сложным он ни был, можно использовать CTE). И затем вы будете использовать его как

SELECT * FROM dbo.GetForPeriod('1-Jan-2010', '31-Jan-2010')
12
ответ дан 3 December 2019 в 08:28
поделиться

Если под VIEW вы подразумеваете собственное представление SQL Server (CREATE VIEW ... ), то вы вообще не можете использовать локальные переменные (вместо них вы будете использовать udf с табличными значениями).

Если вы имеете в виду что-то другое, то добавление DECLARE @StartDate DATETIME, @EndDate DATETIME делает это утверждение парсинг нормальным, это весь SQL?

2
ответ дан 3 December 2019 в 08:28
поделиться
Другие вопросы по тегам:

Похожие вопросы: