关于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后面的? 展开
 我来答
tj_angela
2015-09-22 · TA获得超过7530个赞
知道大有可为答主
回答量:6797
采纳率:75%
帮助的人:2664万
展开全部
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的记录
chinaboyzyq
推荐于2018-03-01 · TA获得超过1.3万个赞
知道大有可为答主
回答量:1.3万
采纳率:89%
帮助的人:3419万
展开全部
把 or 改成and

对于or 来讲如果前面的表达式为真则不再计算后面的表达式。
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
yong378287879
2012-07-24 · TA获得超过139个赞
知道小有建树答主
回答量:258
采纳率:0%
帮助的人:113万
展开全部
你用括号把or前后的条件括起来试一下
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式