热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

oracle中case及其类似用法

在现实数据时,我们为了更直观的显示表内信息,通常会将同类或某个范围内的值归为一类,使用统一的‘新值’取代‘原值’,那么这时候,我们要用到case语句,下面看看case的几种用法吧。...Synta

在现实数据时,我们为了更直观的显示表内信息,通常会将同类或某个范围内的值归为一类,使用统一的‘新值’取代‘原值’,那么这时候,我们要用到case语句,下面看看case的几种用法吧。
 
  1.简单case语句
 
  简单case语句的用法与C#中switch case的用法很类似,case捕获定制,then后返回‘新值’,通常也可以利用该语法判定指定字段是否有指定值得存在,下面通过例子看看它的用法:
 1 select (case acct_month
 2          when '200706' then
 3           '07年6月'
 4          when '200707' then
 5           '07年7月'
 6          else  www.2cto.com  
 7           '其他年份'
 8        end) 年份,
 9        svcnum,
10        fee1,
11        fee2,
12        fee3
13   from TRAIN_TAB_BILLDETAIL;
 
    
 
 
    在这个例子中,如果acct_month的值为200706,那么现实的时候使用‘07年6月’替换原值,在acct_month值不满足任何case条件时,运行else语句,使用else后的数据值替换原值。但是需要注意,在这样一个简单case语句中,不能使用任何比较运算符,同时,when和then后的数据必须与acct_month具有相同的数据类型或能够进行隐式转换,否则报错。  www.2cto.com  
 
  2.case搜索语句
 
  case搜索语句与if…else语句用法类似,进行有条件搜索,返回满足条件的值,在case…when…then…else语法中,when后为比较条件,返回boolean值true或false,若返回false,则执行吓一跳when语句直到比较结果为true时,返回该句then后的值替换原值,若when条件都不满足,则跳转到else,返回else后的匹配值,同时需要注意,返回值类型必须与比较字段的值类型相同或能够通过隐式类型转换,否则返回错误。
看下面的例子:
 
  从下面三张表中返回指定输出格式的数据:

    
 


 
    输出显示‘地市(areadef)’,‘总额分档(fee1+fee2+fee3)’,‘用户数(subscrbid)’,‘入账总额(fee1+fee2+fee3)’,下面看如下代码:
 
select 地域 地市, 总费用分档, count(*) 出账用户数, sum(总收入) 入账收入
  from (select areadef 地域,
               (case
                 when fee1 + fee2 + fee3 >= 0 and fee1 + fee2 + fee3 <10 then
                  &#39;大于等于0,小于10&#39;
                 when fee1 + fee2 + fee3 >= 10 and fee1 + fee2 + fee3 <100 then
                  &#39;大于等于10,小于100&#39;
                 else
                  &#39;大于等于100&#39;
               end) 总费用分档,
               TRAIN_TAB_BILLDETAIL.Subscrbid,
               fee1 + fee2 + fee3 总收入
          from TRAIN_TAB_AREA, TRAIN_TAB_SUBSCRBPRCPLN, TRAIN_TAB_BILLDETAIL
         where TRAIN_TAB_BILLDETAIL.Subscrbid =
               TRAIN_TAB_SUBSCRBPRCPLN.Subscrbid
           and TRAIN_TAB_SUBSCRBPRCPLN.Areaid = TRAIN_TAB_AREA.Areaid)
 group by 地域, 总费用分档  www.2cto.com  
 order by sum(总收入);
 
查询结果为  

    
 
  在这个例子中希望通过表连接统计数据,显示‘总费用分档’则是对总费用额度的判断显示的一个数据域,再通过分组函数进行分组,的出想要看到的结果,通过统计分组显示的结果,较不分组的情况下,更具有‘观大局’的优势。
 
  3.类似用法
    NULLIF(a,b)用法较为简单,当参数a的值等于给定值b时,返回null,都则返回a的值,与NVL()用法较为相似。
    COALESCE(a,b)则在参数a值为空时,返回b值,否则,返回a值。
    这里不提供具体例子了。
 
 
 
作者 Rigwarl.Z

推荐阅读
  • 本文探讨了领域驱动设计(DDD)的核心概念、应用场景及其实现方式,详细介绍了其在企业级软件开发中的优势和挑战。通过对比事务脚本与领域模型,展示了DDD如何提升系统的可维护性和扩展性。 ... [详细]
  • 深入了解 Windows 窗体中的 SplitContainer 控件
    SplitContainer 控件是 Windows 窗体中的一种复合控件,由两个可调整大小的面板和一个可移动的拆分条组成。本文将详细介绍其功能、属性以及如何通过编程方式创建复杂的用户界面。 ... [详细]
  • 开发笔记:2020 BJDCTF Re encode
    开发笔记:2020 BJDCTF Re encode ... [详细]
  • 本文介绍了如何在C#应用程序中有效隐藏SQLCMD命令行窗口,确保程序运行时不会弹出黑色命令提示符窗口。 ... [详细]
  • 本文详细介绍了 iBatis.NET 中的 Iterate 元素,它用于遍历集合并重复生成每个项目的主体内容。通过该元素,可以实现类似于 foreach 的功能,尽管 iBatis.NET 并未直接提供 foreach 标签。 ... [详细]
  • Ihaveastringwithquotesaroundthepathasfollows:我在路径周围有一个带引号的字符串,如下所示:C:\ProgramFiles(x ... [详细]
  • 在软件开发过程中,MD5加密是一种常见的数据保护手段。本文将详细介绍如何在C#中使用两种不同的方式来实现MD5加密:字符串加密和流加密。 ... [详细]
  • 本文介绍如何在华为CE交换机上配置M-LAG(多链路聚合组),以实现CE1和CE2设备作为VLAN 10网关的高可用性。通过详细的配置步骤,确保网络冗余和稳定性。 ... [详细]
  • 本文探讨了使用C#在SQL Server和Access数据库中批量插入多条数据的性能差异。通过具体代码示例,详细分析了两种数据库的执行效率,并提供了优化建议。 ... [详细]
  • 本文详细介绍了如何在C#程序运行期间防止系统进入休眠模式以及显示器关闭,提供了具体的实现代码示例,并解释了其应用场景。这不仅有助于提高程序的稳定性,还能优化能源管理。适合需要处理长时间任务(如下载或批处理)的开发者参考。 ... [详细]
  • Python处理Word文档的高效技巧
    本文详细介绍了如何使用Python处理Word文档,涵盖从基础操作到高级功能的各种技巧。我们将探讨如何生成文档、定义样式、提取表格数据以及处理超链接和图片等内容。 ... [详细]
  • 编写了几个500行左右代码的程序,但基本上解决问题还是面向过程的思维,如何从问题中抽象出类,形成类的划分和设计,从而用面向对象的思维解决问题?有这方面的入门好书吗?最好是结合几个具体的案例分析的 ... [详细]
  • C#设计模式学习笔记:观察者模式解析
    本文将探讨观察者模式的基本概念、应用场景及其在C#中的实现方法。通过借鉴《Head First Design Patterns》和维基百科等资源,详细介绍该模式的工作原理,并提供具体代码示例。 ... [详细]
  • 本文探讨了如何在C# WinForms应用程序中将带有格式(如粗体、下划线等)的RTF文本粘贴到RichTextBox控件中,并确保粘贴后的文本保持原始格式和着色。我们还将介绍一些优化方法,以提高处理效率。 ... [详细]
  • 本文介绍了如何在 C# 和 XNA 框架中实现一个自定义的 3x3 矩阵类(MMatrix33),旨在深入理解矩阵运算及其应用场景。该类参考了 AS3 Starling 和其他相关资源,以确保算法的准确性和高效性。 ... [详细]
author-avatar
9158Zsc
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有