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的记录
把 or 改成and
对于or 来讲如果前面的表达式为真则不再计算后面的表达式。
你用括号把or前后的条件括起来试一下