
关于sql server中 case when then中 or 的用法?
selectid,[name],score=casewhenuscore<60orcscore<70then'不及格'whenuscore<80orcs...
select id,[name],score=case when uscore<60 or cscore<70 then '不及格' when uscore<80 or cscore<90 then '中等' uscore>=80 or cscore>=90 then '优' else ' ' end from userinfo为什么只能判断一个条件 不能判断or后面的?
展开
3个回答
展开全部
case when中的各个条件不能有交集,否则会出现异常
该例的结果应该如下:
select id,[name],
score=case when uscore>=80 or cscore>=90 then '优'
when uscore<60 or cscore<70 then '不及格'
else '中等' end
from userinfo
再看一下case when语法如下: 各个条件表达式要互不相交
case when 条件表达式1 then 结果表达式1
when 条件表达式2 then 结果表达式2
。。。。 else 结果表达式n
end
如果要用到or或者and操作,肯定是在条件表达式中有多个判断逻辑需要操作
比如 case when a>10 or a<5 then '结果1' else '结果2' end
这样就会区分大于10或者小于5的记录
该例的结果应该如下:
select id,[name],
score=case when uscore>=80 or cscore>=90 then '优'
when uscore<60 or cscore<70 then '不及格'
else '中等' end
from userinfo
再看一下case when语法如下: 各个条件表达式要互不相交
case when 条件表达式1 then 结果表达式1
when 条件表达式2 then 结果表达式2
。。。。 else 结果表达式n
end
如果要用到or或者and操作,肯定是在条件表达式中有多个判断逻辑需要操作
比如 case when a>10 or a<5 then '结果1' else '结果2' end
这样就会区分大于10或者小于5的记录
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询