oracle之case函数(case when then else end)用法

本文介绍如何使用SQL的CASE语句将数据库中的状态字段转换为更易读的中文描述,通过具体实例展示了如何将代表状态的字母和数字映射到中文词汇,如“办结”、“作废”和“在途”,从而提升数据展示的直观性和用户体验。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在写项目时,会遇到有字典项的业务,例如数字1代表男,数字2代表女,用做展示的时候,遇到对应数字就展示中文对应的男or女。
现在数据库创建一张表(message_mid),字典项的字段是state:0代表办结,D代表作废,其余代表在结。数据库展示如下:
在这里插入图片描述
要展示的是字段state那一列,展示对应的汉字,语句编写如下:

select regionno,R_NAME,adress,
      case state
      when '0' then
      '办结'
      when 'D' then
      '作废'
      else
      '在途'
      end status,
      opertype from message_mid;

效果如图所示:
在这里插入图片描述
注意:end后面的名字就是数据库最后要展示的字典项的字段名,名字自己随意取

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

菜鸟驿站ㅤ

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值