我正在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中超级弱。搜索这些错误往往会让我陷入与我的不完全相关的其他一些问题。我做错了什么?
答案 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语句只返回一行和一列。