如何在Sql Server(2005)的VIEW中“声明标量变量”

时间:2010-08-13 09:49:59

标签: sql sql-server-2005

我正在尝试在 SQL Server 2005中创建 VIEW

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构造或语句。”

4 个答案:

答案 0 :(得分:12)

正如Alex K所提到的,你应该把它写成内联表值函数。以下是描述它的article

简而言之,语法类似于

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')

答案 1 :(得分:2)

如果通过 VIEW 表示SQL Server本机视图(CREATE VIEW ...),则根本不能使用局部变量(您可以使用表值udf)。

如果您的意思是其他内容,那么添加DECLARE @StartDate DATETIME, @EndDate DATETIME会使该语句解析正确,它是整个SQL吗?

答案 2 :(得分:1)

这是一个使用CTE很好地模拟内部变量构造的示例查询。您可以在您的SQL Server版本中测试它。

def combi(s : Seq[Int]) : Seq[(Int, Int)] = 
    if(s.isEmpty)
         Seq()
    else
        s.tail.flatMap(x=> Seq(s.head -> x, x -> s.head)) ++ combi(s.tail)

产出输出:

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

答案 3 :(得分:-1)

尝试用A.X和A.Y替换所有@X,@ Y,添加到您的代码中: FROM(选择X =&#39; literalX&#39;,Y =&#39; literalY&#39;)A 然后你把所有的文字放在一个地方,只有一个副本。