热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

Oracle中decode函数与casewhen的使用

DECODE()函数,它将输入数与函数中的参数列表相比较,根据输入返回一个对应。函数的参数列表是由若干数及其对应结果组成的若干序偶形式。当然,如果未能与任何一个实参序偶匹配成功,则函数也有默认的返回。区别于SQL的其它函数,DECODE函数还能识别和操作

DECODE()函数,它将输入数与函数中的参数列表相比较,根据输入返回一个对应。函数的参数列表是由若干数及其对应结果组成的若干序偶形式。当然,如果未能与任何一个实参序偶匹配成功,则函数也有默认的返回。 区别于SQL的其它函数,DECODE函数还能识别和操作

DECODE()函数,它将输入数值与函数中的参数列表相比较,根据输入值返回一个对应值。函数的参数列表是由若干数值及其对应结果值组成的若干序偶形式。当然,如果未能与任何一个实参序偶匹配成功,则函数也有默认的返回值。

区别于SQL的其它函数,DECODE函数还能识别和操作空值。

语法:DECODE(control_value,value1,result1[,value2,result2…][,default_result]);

语法解读:control _value试图处理的数值。DECODE函数将该数值与后面的一系列的偶序相比较,以决定返回值。

value1是一组成序偶的数值。如果输入数值与之匹配成功,则相应的结果值将被返回。对应一个空的返回值,可以使用关键字NULL于之对应

result1 是一组成序偶的结果值。

default_result 未能与任何一个值匹配时,函数返回的默认值。

例1:select decode(sign(to_number(to_char(sysdate,'MM'))-6),1,'下半年',-1,'上半年',0,'六月') as MM from dual;

sign()函数根据表达式的值是0、正数还是负数,分别返回0、1、-1;

dual是oracle的虚拟表,比如select sysdate from dual 查询系统当前时间;

此sql根据数据库查询出系统当前时间,取时间的月份,先转换成char型,再将char转换为number型,

当月份减6大于0时,显示下半年,小于0时显示上关年,等于0 时显示六月。

例2:一个员工表,employees和一个部门表,departments;

员工表有员工编号employee_id,员工姓名employee_name,员工工资salary和部门编码department_id;

部门表有部门编号department_id,部门名称department_name;

部题描述:查出各部门的员工工资大于3000和小等于3000的人数。

sql语句:

select d.department_id,
        sum(decode(sign(e.salary - 3000),1,1,-1,0)) maxSal,
        sum(decode(sign(3000 - e.salary),1,1,-1,0)) minSal
        from employees e, departments d
       where e.department_id = d.department_id
       group by d.department_id;


SQL解析:因为当工资小于等于3000时,都返回0,所以用-1代替小于和等于(即0和-1)的情况。

另一解决方法(用case when....then....end):

select d.department_id,
        sum(case when e.salary - 3000 > 0 then 1 else 0 end ) maxSal ,
        sum(case when 3000 - e.salary > 0 then 1 else 0 end ) minSal
        from employees e, departments d
        where e.department_id = d.department_id
        group by d.department_id; 


case when 有多个条件时,用case when .... then .... when ... then .......end

select m.guid as ID,
        case 
          when m.superitemid is null then
           '-1'
          when m.superitemid = '0' then
           '-1'
          else
           m.superitemid
        end as PID,
        m.code || '-' || m.name as TEXT,
        m.code,
        m.name
   from T_PUBMOFDEP m

推荐阅读
  • 数据输入验证与控件绑定方法
    本文提供了多种数据输入验证函数及控件绑定方法的实现代码,包括电话号码、数字、传真、邮政编码、电子邮件和网址的验证,以及报表绑定和自动编号等功能。 ... [详细]
  • 本文介绍了MySQL窗口函数的基本概念、应用场景及常见函数的使用方法。窗口函数在处理复杂查询时非常有用,例如计算每个用户的订单排名、环比增长率、以及动态聚合等。 ... [详细]
  • 本文详细解析了MySQL中常见的几种错误,并提供了具体的解决方法,帮助开发者快速定位和解决问题。 ... [详细]
  • 七大策略降低云上MySQL成本
    在全球经济放缓和通胀压力下,降低云环境中MySQL数据库的运行成本成为企业关注的重点。本文提供了一系列实用技巧,旨在帮助企业有效控制成本,同时保持高效运作。 ... [详细]
  • 在Android应用开发过程中,开发者经常遇到诸如CPU使用率过高、内存泄漏等问题。本文将介绍几种常用的命令及其应用场景,帮助开发者有效定位并解决问题。 ... [详细]
  • 在中标麒麟操作系统上部署达梦数据库及导入SQL文件
    本文档详细介绍了如何在中标麒麟操作系统上安装达梦数据库,并提供了导入SQL文件的具体步骤。首先,检查系统的发行版和内核版本,接着创建必要的用户和用户组,规划数据库安装路径,挂载安装介质,调整系统限制以确保数据库的正常运行,最后通过图形界面完成数据库的安装。 ... [详细]
  • 本文探讨了如何在PHP与MySQL环境中实现高效的分页查询,包括基本的分页实现、性能优化技巧以及高级的分页策略。 ... [详细]
  • 本文介绍了如何通过安装 sqlacodegen 和 pymysql 来根据现有的 MySQL 数据库自动生成 ORM 的模型文件(model.py)。此方法适用于需要快速搭建项目模型层的情况。 ... [详细]
  • H5技术实现经典游戏《贪吃蛇》
    本文将分享一个使用HTML5技术实现的经典小游戏——《贪吃蛇》。通过H5技术,我们将探讨如何构建这款游戏的两种主要玩法:积分闯关和无尽模式。 ... [详细]
  • 本文详细介绍了Oracle 11g中的创建表空间的方法,以及如何设置客户端和服务端的基本配置,包括用户管理、环境变量配置等。 ... [详细]
  • Maven + Spring + MyBatis + MySQL 环境搭建与实例解析
    本文详细介绍如何使用MySQL数据库进行环境搭建,包括创建数据库表并插入示例数据。随后,逐步指导如何配置Maven项目,整合Spring框架与MyBatis,实现高效的数据访问。 ... [详细]
  • 探讨在使用 PL/SQL Developer 12.0 的数据生成器时遇到的中文乱码问题及其解决方案。 ... [详细]
  • 软件测试行业深度解析:迈向高薪的必经之路
    本文深入探讨了软件测试行业的发展现状及未来趋势,旨在帮助有志于在该领域取得高薪的技术人员明确职业方向和发展路径。 ... [详细]
  • 本文介绍了一种使用SQL Server存储过程来实现基于单一条件的高效分页查询的方法。通过示例代码,详细说明了如何构建和执行这种分页查询。 ... [详细]
  • 如何在Django框架中实现对象关系映射(ORM)
    本文介绍了Django框架中对象关系映射(ORM)的实现方式,通过ORM,开发者可以通过定义模型类来间接操作数据库表,从而简化数据库操作流程,提高开发效率。 ... [详细]
author-avatar
100斤的重口味_866
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有