无法在存储过程中执行多个查询而不会出现错误

时间:2016-05-23 23:34:51

标签: sql sql-server tsql

我正在ASP.NET中构建一个Web门户,它允许我们跟踪在我们的环境中发生的一些安全事件,这些安全事件是我们平台专有的。

数据非常简单。我们收集它并将其记录在一个非常基本的表中:

CREATE TABLE [dbo].[tblBonks]
(
    [bonkID] [int] IDENTITY(1,1) NOT NULL,
    [bonkVictim] [nvarchar](50) NOT NULL,
    [bonkMachineID] [nvarchar](max) NULL,
    [bonkUser] [nvarchar](50) NOT NULL,
    [bonkTime] [datetime] NOT NULL,

    CONSTRAINT [PK_tblBonks] 
        PRIMARY KEY CLUSTERED 
)

我有一个存储过程,我的代码调用它来收集24小时,7天和1个月的统计数据。根据我设置的单个变量@Scoreboard,我可以传递一个字符串,以使存储过程生成不同的记分板统计信息。
这一切看起来都很简单。

这是现在存在的存储过程:

CREATE PROCEDURE sp_BuildScoreboard 
     @ScoreBoard nvarchar(25),
     @Day nvarchar(5) OUTPUT,
     @Week nvarchar(5) OUTPUT,
     @Month  nvarchar(5) OUTPUT
AS
BEGIN
    SET NOCOUNT ON;

    IF (@ScoreBoard = 'VICTIM')
    BEGIN
        set @Day = (select TOP(1) bonkVictim, count(bonkVictim) as bonknumber
                    from tblBonks
                    where bonkTime > DATEADD(DAY, -1, SYSDATETIME()) 
                      and bonkVictim != bonkUser
                    group by bonkVictim
                    order by bonknumber desc)

        /* 7 days */
        set @Week = (select TOP(1) bonkVictim, count(bonkVictim) as bonknumber
                     from tblBonks
                     where bonkTime > DATEADD(WEEK, -1, SYSDATETIME()) 
                       and bonkVictim != bonkUser
                     group by bonkVictim
                     order by bonknumber desc)

        /* 1 month */
        set @Month = (select TOP(1) bonkVictim, count(bonkVictim) as bonknumber
                      from tblBonks
                      where bonkTime > DATEADD(MONTH, -1, SYSDATETIME()) 
                        and bonkVictim != bonkUser
                      group by bonkVictim
                      order by bonknumber desc)
    END
    /*ELSE IF (@ScoreBoard = 'LEADER')
    BEGIN
    END
    ELSE IF (@ScoreBoard = 'MACHINE')
    BEGIN
    END*/
END
GO

但是我了解到,由于某些原因,这不起作用。这些应该是三个独立的查询,它们将自己的值返回给输出变量。

我收到此错误:

  

Msg 116,Level 16,State 1,Procedure sp_BuildScoreboard,Line 38
  当未使用EXISTS引入子查询时,只能在选择列表中指定一个表达式。

     

Msg 116,Level 16,State 1,Procedure sp_BuildScoreboard,Line 41
  当未使用EXISTS引入子查询时,只能在选择列表中指定一个表达式。

     

Msg 116,Level 16,State 1,Procedure sp_BuildScoreboard,Line 42
  当未使用EXISTS引入子查询时,只能在选择列表中指定一个表达式。

我在T-SQL中超级弱。搜索这些错误往往会让我陷入与我的不完全相关的其他一些问题。我做错了什么?

2 个答案:

答案 0 :(得分:1)

首先,养成在每个语句末尾加分号的习惯。这不是问题(在这种情况下)。相反,写出语法正确的语句:

       set @Day = (select TOP(1) bonkVictim
                   from tblBonks
                   where bonkTime > DATEADD(DAY, -1, SYSDATETIME()) and
                          bonkVictim <> bonkUser
                    group by bonkVictim
                    ORDER BY count(bonkVictim) desc
                   );

请注意,子查询是标量子查询。它只能返回一列,最多只能返回一行。两列应该生成错误。

答案 1 :(得分:0)

您需要从每个bonkVictim,语句中删除select,以便select语句只返回一行和一列。