1:使用decode判断字符串是否一样

DECODE(value,if1,then1,if2,then2,if3,then3,...,else)

含义为
IF 条件=值1 THEN
    RETURN(value 1)

ELSIF 条件=值2 THEN
    RETURN(value 2)
    ......

ELSIF 条件=值n THEN
    RETURN(value 3)
ELSE
    RETURN(default)
END IF

select empno,

decode(empno,7369,'smith',7499,'allen',7521,'ward',7566,'jones','unknow')

as name from emp where rownum<=10

2:使用decode比较大小

select decode(sign(var1-var2),-1,var1,var2) from dual

sign()函数根据某个值是0、正数还是负数,分别返回0、1、-1

select decode(sign(100-90),-1,100,90) from dual

select decode(sign(100-90),1,100,90) from dual

3:使用decode函数分段

工资大于5000为高薪,工资介于3000到5000为中等,工资小于3000为低薪

SELECT

ename,sal,

DECODE(SIGN(sal - 5000),

1,

'high sal',

0,

'high sal',

- 1,

DECODE(SIGN(sal - 3000),

1,

'mid sal',

0,

'mid sal',

- 1,

DECODE(SIGN(sal - 1000),

1,

'low sal',

0,

'low sal',

- 1,

'low sal')))

FROM

emp

4:利用decode实现表或者视图的行列转换

SELECT

SUM(DECODE(ENAME,'SMITH',SAL,0)) SMITH,

SUM(DECODE(ENAME,'ALLEN',SAL,0)) ALLEN,

SUM(DECODE(ENAME,'WARD',SAL,0))  WARD,

SUM(DECODE(ENAME,'JONES',SAL,0)) JONES,

SUM(DECODE(ENAME,'MARTIN',SAL,0)) MARTIN FROM EMP

5:使用decode函数来使用表达式来搜索字符串

decode (expression, search_1, result_1, search_2,
result_2, ...., search_n, result_n, default)

decode函数比较表达式和搜索字,如果匹配,返回结果;如果不匹配,返回default值;如果未定义default值,则返回空值。

SELECT

ENAME,

SAL,

DECODE(INSTR(ENAME, 'S'),

0,

'不含有s',

'含有s') AS INFO

FROM

EMP

比如我要查询某班男生和女生的数量分别是多少?

通常我们这么写:
select count(*) from 表 where 性别 = 男;
select count(*) from 表 where 性别 = 女;

要想显示到一起还要union一下,太麻烦了

用decode呢,只需要一句话

select sum(decode(性别,男,1,0)),sum(decode(性别,女,1,0)) from 表

decode函数的几种用法的更多相关文章

  1. Mysql中decode函数的几种用法

    1.使用decode判断字符串是否一样 decode(value,if1,then1,if2,then2,if3,then3,...,else) 含义为 IF 条件=值1 THEN RETURN(va ...

  2. getline()函数的两种用法

    getline()函数的输入流对象可以是标准输入流对象cin,也可以是一个文件输入流对象fin; (1)输入流对象的成员函数(有三个参数,一般除非需要自己选定停止符,并不推荐使用): basic_is ...

  3. jQuery中$()函数的7种用法汇总

    前言 jQuery对象是一个类数组的对象,含有连续的整形属性以及一系列的jQuery方法.它把所有的操作都包装在一个jQuery()函数中,形成了统一(也是惟一)的操作入口.其中我们用的非常频繁的一个 ...

  4. PHP回调函数的几种用法

    PHP回调函数的实现方法 目录 前言      全局函数的回调      类静态函数的回调      对象的方法的回调      PHP事件模型(观察者模式)的实现思路    前言 最近在开发一个PH ...

  5. JS函数的几种用法

    1.正常使用:

  6. Shell函数的7种用法介绍

    1. 在shell文件内部定义函数并引用: 复制代码代码如下: [~/shell/function]# cat factorial.sh #!/bin/bashfunction factorial{f ...

  7. underscore函数存在两种用法

    var _ = require('underscore'); var a = {"a": 1, "b": 2}; console.log(_(a).size() ...

  8. js 函数arguments一种用法

    无意改同事的代码发现的 function toggle(){ var _arguments=arguments; var count=0; $("#more").click(fun ...

  9. Oracle 中 decode 函数用法

    Oracle 中 decode 函数用法 含义解释:decode(条件,值1,返回值1,值2,返回值2,...值n,返回值n,缺省值) 该函数的含义如下:IF 条件=值1 THEN RETURN(翻译 ...

随机推荐

  1. 【实战】SpringBoot + KafKa

    1.配置pom包 <dependency> <groupId>org.springframework.kafka</groupId> <artifactId& ...

  2. 5分钟学会Java9-Java11的七大新特性

    现在Java有多元化的发展趋势,既有JS又有C++还有C#的影子,不学习那是不行滴. 来来来,花5分钟看看Java9-Java11的七大新特性,还有代码样例. Java11 发布了,然而很多公司还在用 ...

  3. ASP.NET Core on K8S学习初探(2)K8S基本概念快速一览

    在上一篇<单节点环境搭建>中,通过Docker for Windows在Windows开发机中搭建了一个单节点的K8S环境,接下来就是动人心弦的部署ASP.NET Core API到K8S ...

  4. Windows上安装PyV8

    Windows上安装PyV8 在PyPi网站上有Windows的exe格式的包连接, PyPi, Google注意网络是否通畅! 官网地址 Google PyV8 双击安装, 注意, 一般会自动检测P ...

  5. Jenkins Email Extension插件模板

    Jenkins Email Extension插件模板 <!DOCTYPE html> <html> <head> <meta charset="U ...

  6. 漫谈Redis分布式锁实现

    在Redis上,可以通过对key值的独占来实现分布式锁,表面上看,Redis可以简单快捷通过set key这一独占的方式来实现分布式锁,也有许多重复性轮子,但实际情况并非如此.总得来说,Redis实现 ...

  7. JavaScript的数据类型及其检测

    一.什么是数据类型 1.基本类型 值是不可改变的 var name = 'java'; name.toUpperCase(); // 输出 'JAVA' console.log(name); // 输 ...

  8. JS高级程序设计第3章--精简版

    前言:纯手打!!!按照自己思路重写!!!这次是二刷了,想暑假做一次完整的笔记,但用本子来写笔记的话太贵了,可能哪天还丢了..所以还是博客好== 第三章:基本概念(语法.数据类型.流控制语句.函数) 3 ...

  9. django的阶段总结

    Django回顾 1 web应用 本质是基于socket实现的应用程序 浏览器-----------服务器 2 http协议:应用层协议 1 基于TCP协议 2 基于请求响应 3 短连接 4 无状态保 ...

  10. vue中轮播图的实现

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...