Подтвердить что ты не робот

Как "Объявить скалярную переменную" в VIEW на Sql Server (2005)

Я пытаюсь создать VIEW в 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 объявления Declare не поддерживается."

4b9b3361

Ответ 1

Как упоминал 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')

Ответ 2

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

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

Ответ 3

Вот пример запроса, который использует CTE, чтобы хорошо эмулировать внутреннюю конструкцию переменных. Вы можете протестировать его в своей версии SQL Server.

CREATE VIEW vwImportant_Users AS
WITH params AS (
    SELECT 
    varType='%Admin%', 
    varMinStatus=1)
SELECT status, name 
    FROM sys.sysusers, params
    WHERE status > varMinStatus OR name LIKE varType

SELECT * FROM vwImportant_Users

выход:

status  name
12      dbo
0       db_accessadmin
0       db_securityadmin
0       db_ddladmin

также через JOIN

WITH params AS ( SELECT varType='%Admin%', varMinStatus=1)
SELECT status, name 
    FROM sys.sysusers INNER JOIN params ON 1=1
    WHERE status > varMinStatus OR name LIKE varType

также через CROSS APPLY

WITH params AS ( SELECT varType='%Admin%', varMinStatus=1)
SELECT status, name 
    FROM sys.sysusers CROSS APPLY params
    WHERE status > varMinStatus OR name LIKE varType

Ответ 4

попробуйте заменить все ваши @X, @Y на A.X и A.Y, добавьте в свой код: FROM (SELECT X = 'literalX', Y = 'literalY') A то вы положили все свои литералы в одном месте и имеете только одну копию.