Oracle函数之DECODE函数

Oracle函数之DECODE函数1.语法2.用途DECODE函数将expr与search的值逐个比较。如果expr与search值相等,Oracle返回search相应的result。如果expr与search值都不匹配,Oracle返回default,如果没有函数中没有赋值default,Oracle返回null。这些参数可以是任何数字类型(NUMBER,BINARY_F…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

1.语法

在这里插入图片描述

2.用途

DECODE 函数将 expr 与 search 的值逐个比较。如果 expr 与 search 值相等,Oracle 返回 search 相应的 result。如果 expr 与 search 值都不匹配,Oracle 返回 default,如果没有函数中没有赋值 default,Oracle 返回 null。

这些参数可以是任何数字类型(NUMBER, BINARY_FLOAT, 或者 BINARY_DOUBLE)或者字符类型。

  • 如果 expr 和 search 是字符数据,返回值是 VARCHAR2 类型
  • 如果 search-result 对是数字类型,然后 Oracle 比较所有的 search-result 和 expr,来确定数值优先级最高的参数,隐式转换其他的参数为其数据类型,并且返回值也是此数据类型。

search, result, 和 default 值可以是表达式。Oracle数据库使用短路求值(short-circuit evaluation)。数据库在每个 search 表达式与 expr 对比之前进行求值,而不是先与 expr 比较再求 search 表达式的值。因此,如果之前的 search 表达式的值与 expr 相等,Oracle不会计算后面的 search 表达式。

Oracle在比较之前自动转换 expr 和每个 search 值为第一个 search 值的数据类型。Oracle自动转换返回值数据类型为第一个 search 值的数据类型。如果第一个 result 是字符数据类型或者是null,Oracle转换返回值类型为VARCHAR2。

在DECODE函数中,Oracle认为两个null是相等的。如果 expr 是null,第一个 search 也是null,Oracle会返回第一个 search 的 result。

DECODE函数的参数(包括 expr, searches, results, 和 default)最多为255个。

例子

如果 warehouse_id 是1,函数返回 ‘Southlake’,如果 warehouse_id 是2,返回 ‘San Francisco’ 等等。如果 warehouse_id 不是 1, 2, 3, 或者 4, 函数返回 ‘Non domestic’。

SELECT product_id,
       DECODE (warehouse_id, 1, 'Southlake', 
                             2, 'San Francisco', 
                             3, 'New Jersey', 
                             4, 'Seattle',
                                'Non domestic') "Location" 
  FROM inventories
  WHERE product_id < 1775
  ORDER BY product_id, "Location";
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/160108.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • ASMM自动管理的功能[通俗易懂]

    ASMM自动管理的功能[通俗易懂]AutomaticSharedMemoryManagement(ASMM)是ORACLE10g另外一个自动管理的功能。[@more@]AutomaticSharedMemoryManagement(ASMM)是ORA…

  • mt4平台如何下载_mt4交易平台

    mt4平台如何下载_mt4交易平台当前我们若要顺势进场交易,除了要选择一个好的交易平台,一个实用的投资软件也必不可少。虽然目前市面上流行着多种mt4平台,优质型的不少,但也不乏“山寨版”,后者多为不法平台为了恶意操纵显示的行情以坑骗投资者的资金而自主研发的,危害性极大。那mt4平台哪个比较好用更安全呢?务必要留意其下载渠道的正规性,通常,正规安全有监管的平台具有好的市场口碑,能提供更可靠的投资环境,其专有的mt4平台是为安全的下载渠道。投资者除了要知道mt4平台哪个比较好用更好之外,还应充分了解下载何种软件更利于我们顺畅交易。考虑到当前

  • Document类型、HTMLDocument类型和document对象的区别[通俗易懂]

    Document类型、HTMLDocument类型和document对象的区别[通俗易懂]Dcoment表示文档,这里的文档可以是HTML文档,也可以是XML文档,换句话说Document类型能表示HTML和XML等文档; HTMLDocument对象继承自Document对象,专用于表示HTML文档; document对象是HTMLDocument对象的一个实例,表示整个HTML页面,又叫做页面的根节点;Document对象(根节点)的特征:<!DOCTYPEht…

  • java 调用webservice asmx「建议收藏」

    java 调用webservice asmx「建议收藏」用的jar包axis,可以在http://download.csdn.net/download/xiaoyong8823/4391971这里下载因为最近有个项目要调用webservice接口,之前接触的都是Java开发服务端和客户端的接口,开发前服务端一般会给个以http://xxx/services?wsdl地址的文件或者地址。这次对方给我个http://xxxx/serv

  • unity htc vive使用

    unity htc vive使用

  • 实验室设备管理系统c语言程序设计_设备管理系统怎么实现

    实验室设备管理系统c语言程序设计_设备管理系统怎么实现#include#include#includetypedefstructequipment{intnum;//编号charname[20];//名称charmodel[20];//型号charfactory[20];//厂家charbuy_date[20];//购买日期struc

    2022年10月13日

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号