DB2 的 case when then else end 条件分支的处理

2024-06-11 07:58

本文主要是介绍DB2 的 case when then else end 条件分支的处理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

两种语法模式:


(1):只有一个分支

 

     CASE
        WHEN 条件  THEN 结果1
        ELSE            结果2
      END
(2):支持多种分支

 

     CASE 表达式1
        WHEN 表达式2   THEN 结果1
        ELSE            结果2
   END
上面的WHEN可以重复多次,

 

===================

 

简单示例:

 

  1. select    
  2.     case when 1 = 1  
  3.     then 1  
  4.     else 2  
  5.     end;  
  1. select    
  2.     case 2  
  3.     when 1 then 1  
  4.     when 2 then 2  
  5.     when 3 then 3  
  6.     else 4  
  7.     end;  

============================

 

 

下面详细的各举几个例子,这些例子可以用于ESQL和交互式的SQL中
eg1:处理被0除

[java]  view plain copy
  1. SELECT   
  2. CASE   
  3. WHEN fileld1=0 THEN 0  
  4. ELSE fileld2/field1  
  5. END  
  6. FROM  FILE  


eg2:字段值对应转换
[java]  view plain copy
  1. SELECT ORDNO,CUSNAM,SHIPDATE,CASE  
  2.                 WHEN SHIPDATE<CURDATE()  THEN 'OVERDUE'  
  3.                 WHEN SHIPDATE=CURDATE()  THEN 'PROCESSING'  
  4.                 WHEN SHIPDATE>;CURDATE()  THEN 'ACTIVE'  
  5.               END  
  6. FROM FILE  


eg3:获取月份的名字:上面的例子
[java]  view plain copy
  1. SELECT ORDNO,CUSNO,  
  2.    CASE  MONTH(SHIPDATE)  
  3.    WHEN  '01'   THEN 'Jan'  
  4.    WHEN  '02'   THEN 'Feb'  
  5.    WHEN  '03'   THEN 'Mar'  
  6.    WHEN  '04'   THEN 'Apr'  
  7.    WHEN  '05'   THEN 'May'  
  8.    WHEN  '06'   THEN 'Jun'  
  9.    WHEN  '07'   THEN 'Jul'  
  10.    WHEN  '08'   THEN 'Aug'  
  11.    WHEN  '09'   THEN 'Sep'  
  12.    WHEN  '10'   THEN 'Oct'  
  13.    WHEN  '11'   THEN  'Nov'  
  14.    WHEN  '12'   THEN  'Dec'  
  15.    END  
  16. FROM FILE  
  

 

===================

 

CASE很好用,不仅SELECT可以用,UPATE里面也蛮灵

以上是关于查询的  下面再来个 update的

 

贴代码直观:

 

 

[c-sharp]  view plain copy
  1. UPDATE properities  
  2. SET   taxrate=  
  3.    CASE   
  4.        WHEN area<10000 THEN 0.05  
  5.        WHEN area<20000 THEN 0.07  
  6.        ELSE 0.09  
  7.    END  

这篇关于DB2 的 case when then else end 条件分支的处理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1050591

相关文章

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整

C#使用SQLite进行大数据量高效处理的代码示例

《C#使用SQLite进行大数据量高效处理的代码示例》在软件开发中,高效处理大数据量是一个常见且具有挑战性的任务,SQLite因其零配置、嵌入式、跨平台的特性,成为许多开发者的首选数据库,本文将深入探... 目录前言准备工作数据实体核心技术批量插入:从乌龟到猎豹的蜕变分页查询:加载百万数据异步处理:拒绝界面

SpringIntegration消息路由之Router的条件路由与过滤功能

《SpringIntegration消息路由之Router的条件路由与过滤功能》本文详细介绍了Router的基础概念、条件路由实现、基于消息头的路由、动态路由与路由表、消息过滤与选择性路由以及错误处理... 目录引言一、Router基础概念二、条件路由实现三、基于消息头的路由四、动态路由与路由表五、消息过滤

Springboot处理跨域的实现方式(附Demo)

《Springboot处理跨域的实现方式(附Demo)》:本文主要介绍Springboot处理跨域的实现方式(附Demo),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录Springboot处理跨域的方式1. 基本知识2. @CrossOrigin3. 全局跨域设置4.

python+opencv处理颜色之将目标颜色转换实例代码

《python+opencv处理颜色之将目标颜色转换实例代码》OpenCV是一个的跨平台计算机视觉库,可以运行在Linux、Windows和MacOS操作系统上,:本文主要介绍python+ope... 目录下面是代码+ 效果 + 解释转HSV: 关于颜色总是要转HSV的掩膜再标注总结 目标:将红色的部分滤

Python实现自动化接收与处理手机验证码

《Python实现自动化接收与处理手机验证码》在移动互联网时代,短信验证码已成为身份验证、账号注册等环节的重要安全手段,本文将介绍如何利用Python实现验证码的自动接收,识别与转发,需要的可以参考下... 目录引言一、准备工作1.1 硬件与软件需求1.2 环境配置二、核心功能实现2.1 短信监听与获取2.

Python使用date模块进行日期处理的终极指南

《Python使用date模块进行日期处理的终极指南》在处理与时间相关的数据时,Python的date模块是开发者最趁手的工具之一,本文将用通俗的语言,结合真实案例,带您掌握date模块的六大核心功能... 目录引言一、date模块的核心功能1.1 日期表示1.2 日期计算1.3 日期比较二、六大常用方法详

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件

Java使用多线程处理未知任务数的方案介绍

《Java使用多线程处理未知任务数的方案介绍》这篇文章主要为大家详细介绍了Java如何使用多线程实现处理未知任务数,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 知道任务个数,你可以定义好线程数规则,生成线程数去跑代码说明:1.虚拟线程池:使用 Executors.newVir

一文带你深入了解Python中的GeneratorExit异常处理

《一文带你深入了解Python中的GeneratorExit异常处理》GeneratorExit是Python内置的异常,当生成器或协程被强制关闭时,Python解释器会向其发送这个异常,下面我们来看... 目录GeneratorExit:协程世界的死亡通知书什么是GeneratorExit实际中的问题案例