Как "объявить скалярную переменную" в представлении в Sql Server (2005)
Im пытается создать посмотреть на SQL Server 2005.
код SQL работает как таковой (Im использует его в VS2008), но в SQL Server Im не удается сохранить его, так как появляется сообщение об ошибке "объявить скалярную переменную @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
но это не сделало трюк, как я и ожидал - он только дал мне еще одно всплывающее сообщение:
" конструкция или инструкция Declare cursor SQL не поддерживается."
4 ответов
Как упоминал Алекс К, вы должны написать его как встроенную табличную функцию. Вот это статьи что описывает об этом.
короче говоря, синтаксис будет чем-то вроде
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')
Если посмотреть вы имеете в виду собственное представление SQL Server (CREATE VIEW ...
), то вы не можете использовать локальные переменные вообще (вместо этого вы бы использовали табличное значение udf).
Если вы имеете в виду что-то другое, то добавляем DECLARE @StartDate DATETIME, @EndDate DATETIME
делает этот оператор разбором отлично, это вся SQL?
вот пример запроса, который использует 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
попробуйте заменить все ваши @X, @Y на A. X и A. Y, добавьте в свой код: Из (выберите X = 'literalX', Y = 'literalY') A тогда вы поместили все свои литералы в одно место и имеете только одну их копию.