当前位置: 首页 > 面试题库 >

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

浦琪
2023-03-14
问题内容

我试图在 SQL Server* 2005中创建一个 VIEW*

SQL代码按这种方式工作(在VS2008中使用I麓m),但是在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构造或语句。”


问题答案:

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


 类似资料:
  • 问题内容: 如何在mysql中声明变量,以便第二个查询可以使用它? 我想写一些像: 问题答案: MySQL中主要有三种类型的变量: 用户定义的变量 (以开头): 您可以访问任何用户定义的变量,而无需对其进行声明或初始化。如果引用的变量尚未初始化,则其值为和字符串类型。 您可以使用或语句来初始化变量: 要么 可以从一组有限的数据类型中为用户变量分配一个值:整数,十进制,浮点数,二进制或非二进制字符串

  • 问题内容: 我有一个Netezza查询,在其中我引用了一系列案例陈述中的几个日期。而不是每次我都想在开始时将一个变量置为一个变量并在整个查询中都使用它时,而不是替换所有这些日期。在SAS中,我会这样做: 问题答案: 不幸的是,Netezza中没有程序SQL扩展,您无法将这样的变量用作SQL语言本身的一部分。纯粹的SQL解决方案将涉及一些麻烦,例如加入CTE并返回该值。但是,NZSQL CLI确实允

  • 问题内容: 我有以下模板: 并最终以: 有办法吗? 问题答案: 更新资料 我们可以像这样创建指令并调用它 ng-var.directive.ts 通过此指令,我们可以使用以下命令 要么 要么 要么 原始答案 角v4 1)+ + 2)+ + 视图 component.ts 3)如果您不想创建包装器,可以使用 视图 正如@基思在评论中提到的 这在大多数情况下都可以使用,但这不是通用解决方案,因为它依赖

  • 问题内容: 如何在JavaScript中声明全局变量? 问题答案: 如果必须在生产代码中生成全局变量(应避免使用),请 始终 明确 声明它们: 虽然可以通过省略来定义全局变量(假设没有同名的局部变量),但这样做会生成 隐式 全局,这是一件不好的事情,并且在 严格模式下 会产生错误。

  • 我在typescript中声明了一个全局变量,类似于:global。test=“something”我尝试这样做,我得到错误属性“test”在类型“Global”上不存在。

  • 问题内容: 如何声明用于PostgreSQL 8.3查询的变量? 在MS SQL Server中,我可以这样做: 我如何在PostgreSQL中做同样的事情?根据文档,变量被简单地声明为“名称类型;”,但这给了我一个语法错误: 有人可以给我一个正确语法的例子吗? 问题答案: PostgreSQL中没有这样的功能。您只能在pl / PgSQL(或其他pl / *)中执行此操作,而不能在普通SQL中执