关于sql server中 case when then中 or 的用法?
答案:3 悬赏:80 手机版
解决时间 2021-03-26 05:50
- 提问者网友:容嬷嬷拿针来
- 2021-03-25 20:30
关于sql server中 case when then中 or 的用法?
最佳答案
- 五星知识达人网友:神鬼未生
- 2021-03-25 21:25
把 or 改成and
对于or 来讲如果前面的表达式为真则不再计算后面的表达式。
对于or 来讲如果前面的表达式为真则不再计算后面的表达式。
全部回答
- 1楼网友:青灯有味
- 2021-03-25 23:47
你用括号把or前后的条件括起来试一下
- 2楼网友:撞了怀
- 2021-03-25 22:23
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的记录
我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息
大家都在看
推荐资讯