首页 > 解决方案 > 这返回了超过 1 个值

问题描述

我运行以下查询:

create function passs (@studentid nvarchar(50),@courseid nvarchar(50))
returns char
as
begin
declare @k char
if((select Grades.grade from Grades where Grades.Courses_id=@courseid AND 
Students_id=@studentid) >60)
set @k='pass'
else
set @k='no pass'
return @k
end

当我运行这个:

select Grades.Courses_id,dbo.pass(Grades.Students_id,Grades.Courses_id) 
,Grades.Students_id,Grades.grade from Grades

我懂了

消息 512,级别 16,状态 1,第 1 行子查询返回超过 1 个值。当子查询跟随 =、!=、<、<=、>、>= 或子查询用作表达式时,这是不允许的。

标签: sql-servertsql

解决方案


您需要指定当学生在同一班级有多个成绩时该怎么做 - 这就是您遇到的错误。

这是一种可能性:

create function passs (@studentid nvarchar(50), @courseid nvarchar(50))
    returns varchar(255)
as
begin
    declare @k varchar(255);

    select @k = (case when min(g.grade) > 60 then 'pass' else 'no pass' end)
    from grades g
    where g.Courses_id = @courseid 
      AND g.Students_id = @studentid

    return @k;
end;

笔记:

  • 声明了返回字符串的长度——你的值有多个字符。
  • 声明的长度@k
  • 将逻辑组合成一个查询。
  • 用于min()减少查询返回到单行以避免您的特定问题。

推荐阅读