case when 作为条件_sqlserver条件分支case when使用教程

在sqlserver的条件分支case when有两种写法:

1)case 字段 when 值 then 返回值 when 值2 then 返回值2 end

2)case when 条件1 then 返回值1 when 条件2 then 返回值2 end

方法步骤:

1.打开“SQL Server Management Studio”管理工具,创建一张测试表:

CREATE TABLE tblCaseWhen(

Id varchar(40) NOT NULL,

Col1 varchar(50) NULL,

Col2 int NULL,

Col3 varchar(50) NULL,

Col4 varchar(50) NULL

)

dc6cbdcab688b9ac48176d0aa2d85a0c.png

2.往测试表中插入测试数据:

insert into tblCaseWhen(Id, Col1, Col2) values('1', '第1行第2列', 10);

insert into tblCaseWhen(Id, Col1, Col2) values('2', '第2行第2列', 20);

insert into tblCaseWhen(Id, Col1, Col2) values('3', '第3行第2列', 30);

insert into tblCaseWhen(Id, Col1, Col2) values('4', '第4行第2列', 40);

insert into tblCaseWhen(Id, Col1, Col2) values('5', '第5行第2列', 50);

dc5ab0f7e4b9e181ca1e4d5d2fbcaf9c.png

3.查询表中插入的测试数据:

select * from tblCaseWhen;

d5f86ab872ca3700f11bee688af227b7.png

4.使用第一种case when 查询数据改变Col3返回的值,数据库的值不会变。

select Id, Col1, Col2,

Col3 = (case Col2 when 10 then Col2 + 10 when 20 then Col2 + 20 else Col2 + 50 end ), Col4

from tblCaseWhen

280081a3f5d07f545df8217d6210d695.png

5.使用第二种 case when 修改Col4列的值,范围大的条件在前面。

update tblCaseWhen

set Col4 = (case

when Col2 > 10 then '大于10'

when Col2 > 40 then '大于40'

else 'else值'

end)

c00bea61f58859305e9244b212094a45.png

6.查询修改后的数据,从结果可以看到,匹配到第一个条件后,后面的when就不执行了,所以,范围大的条件不能放在前面。

select * from tblCaseWhen;

8a6455c0b59c228d348efcf2a50dd1e5.png

7.使用第二种case when,将范围大的条件移到后面,结果就如预期的显示了。

update tblCaseWhen

set Col4 = (case

when Col2 > 40 then '大于40'

when Col2 > 10 then '大于10'

else 'else值'

end)

fda4d39e70dd54950394bfaa509cead0.png
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值