Oracle ~ case when then的使用

先上一段 代码 

select c.containername,pb.productname || '('||p.productrevision||')' as product
 ,pt.producttypename,
ms.sw_location2,ms.sw_lot,ms.sw_materialstockname,ms.sw_stockqty,
ms.sw_loadedqty,ms.sw_totalqty,u.uomname,
r.resourcename || r.description as 设备,rt.resourcetypename,ms.sw_carriername,
case ms.sw_instocktype when '0' then '半成品'
when  '1' then '原材料'
when  '2' then '在制品'
when  '3' then '成品' end as sw_instocktype,  
s.shiftname,ms.sw_instockdate
from sw_materialstock ms
left join container c on c.containerid = ms.sw_containerid
left join product p  on p.productid = ms.sw_productid
left join productbase pb on pb.productbaseid = p.productbaseid
left join producttype pt on pt.producttypeid = p.producttypeid
left join resourcedef r on r.resourceid = ms.sw_resourceid
left join shift s on s.shiftid = ms.sw_shiftid
left join uom u  on u.uomid = ms.sw_uomid
left join resourcetype rt on rt.resourcetypeid = r.resourcetypeid
where 1 = 1 

 比方说,上图中sw_instockType 存的是枚举类型,在业务中0代表半成品,那么then的后面就跟你想要在展示的内容,最后以end结束,当然建议另起名 as XXX ,比如上图中的 as sw_nstockType

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值