SQL CASE 的用法
admin
2023-05-17 00:42:04
0
  1. --简单case函数

    case sex

      when '1' then '男'

      when '2' then '女’

      else '其他' end


    --case搜索函数

    case when sex = '1' then '男'

       when sex = '2' then '女'

       else '其他' end  



这两种方式,可以实现相同的功能。简单case函数的写法相对比较简洁,但是和case搜索函数相比,功能方面会有些限制,比如写判定式。

还有一个需要注重的问题,case函数只返回第一个符合条件的值,剩下的case部分将会被自动忽略。

比如说,下面这段sql,你永远无法得到“第二类”这个结果:


case when col_1 in ('a','b') then '第一类'
   when col_1 in ('a') then '第二类'
   else '其他' end  

-------------------------------------------------------------------------------------------------------------------


2.批量更新数据

--假设状态只有3个选项,把所有FStatus=3的更新为1,FStatus=88的更新为5,FStatus=99的更新为9,

update T_SUF_Barcode set FStatus=(case FStatus

                     when '3' then '1' 

 when '88' then '55'

 else FStatus  end) 

 where   FBarcode  between '180121702150001' and '180121702153000'

----------------------------------------------------------------------------------------------------------------


3.将条码表中的状态用中文表示


select fstatus from T_SUF_Barcode t1   where   FBarcode  between '180121702150001' and '180121702153000'

--------------------------------------------------------------------------------------------------------------------

fstatus

1

...

5

...

5

9

...

---------------------------------------------------------------------------------------------------------------------


select t1.FBarcode, (case t1.FStatus

                   when  1 then '正常'

                   when  5 then '未知'

                   when  9 then '作废' end)状态

 from T_SUF_Barcode t1

 where   FBarcode  between '180121702150001' and '180121702153000'


FBarcode状态

180121702150001正常

180121702150002...

180121702150003 未知

180121702150004...

180121702150011作废

180121702150012...




4.将sum与case结合使用,可以实现分段统计。
     如果现在希望将上表中各种状态的条码进行统计,sql语句如下:


select

   sum(case t1.FStatus when 1 then 1  end)正常,

   sum(case t1.FStatus when 5 then 2  end)未知,

   sum(case  when t1.FStatus !=1 and t1.FStatus!=5 then 1  end)作废

from T_SUF_Barcode t1  where   FBarcode  between '180121702150001' and '180121702153000'


--sum求和,当为5时,更新为2,并求和符合条件的2。这里正常,未知,作废符合条件的各有1000个数据。


正常 未知          作废

1000 2000(1000*2)   1000


               --------------------------------------------

   

select

   count(case t1.FStatus when 1 then 1  end)正常,

   count(case t1.FStatus when 5 then 1  end)未知,

   count(case  when t1.FStatus !=1 and t1.FStatus!=5 then 1  end)作废

from T_SUF_Barcode t1  where   FBarcode  between '180121702150001' and '180121702153000'


--统计符合条件的个数。


正常 未知 作废

1000 1000 1000


相关内容

热门资讯

美军下一代空空导弹AIM-26... 【文/观察者网 山猫】据专业航空新闻网站“航空学家”(The Aviationist)5月15日报道...
燃气热水器多少升代表什么意思 燃气热水器的升数指的就是其每分钟的热水流量,这个流量等于(△T25℃×X流量)÷Y设定温度。可以简单...
燃气热水器鸣笛 1、强排式热水器本身与自来水管、烟管会造成共振声。2、强排式热水器风机的前清扫工作时发出的响声。3、...
热水器排烟管可以排到烟道吗 不可以,管道内有大量的油烟及高温,油烟和粉尘相互造成影响,二者混在一起时间长了就不能正常工作,废气也...
女子贴条提醒邻居“别在我家门口... “我带着耳塞睡觉,女邻居雇开锁师傅撬开了我家门,冲进来对我动手。”林女士回忆此事,直言当时一脸懵。凌...
【清风轩】新书推荐《科技共和国... 题字:郭宝庆 清风轩 | 图书推荐 出版社:中信出版集团 作者:亚历山大·卡普,尼古拉斯·扎米斯卡...
荣耀亲选LCHSE开放式耳机3... 荣耀亲选LCHSE开放式耳机3(以下简称荣耀亲选开放式耳机3)终于上手了,顾名思义开放式耳机就是不同...
科大讯飞让AI真正走进课堂,因... 2026世界数字教育大会于杭州召开,聚焦人工智能与教育融合发展,集中呈现技术赋能教育变革的最新进展。...