• Oracle:常用函数CASE WHEN,DECODE,NVL,SUBSTR,listagg,instr,to_char,to_number


    之前在学习中只用了简单的查询,最近工作用遇到一些好玩的函数,现在记录一下

    1.CASE WHEN

    case when
    意思就是查询CUST_INFO 表,当字段CUST_TYPE 的值为“man”的时候,替换显示为“男”否则显示“女”。最后查询的结果是一列

    SELECT CASE CUST_TYPE WHEN 'man' THEN '男' ELSE '女' END sex
    FROM CUST_INFO ;
    
    CASE WHEN CUST_TYPE='man' THEN '男' 
         WHEN CUST_TYPE='woman' THEN '男' 
         WHEN CUST_TYPE='animal' THEN '动物'  ELSE '什么鬼' END
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    'man’和’男’数据类型不一致则报错:
    [Err] ORA-00932: 数据类型不一致: 应为 CHAR, 但却获得 NUMBER

    2.DECODE

    decode的使用和case when一样

    SELECT DECODE(CUST_TYPE ,'man','男','女')  sex
    FROM CUST_INFO ;
    
    SELECT DECODE(CUST_TYPE ,'man','男','woman','女','什么鬼')  sex
    FROM CUST_INFO ;
    
    • 1
    • 2
    • 3
    • 4
    • 5

    3.NVL(判空函数)

    SELECT nvl(CUST_TYPE ,'空')  sex
    FROM CUST_INFO ;
    
    --如果你只是想判断是否为空,不想要原来的值
    SELECT nvl(CUST_TYPE ,'空','不空')  sex
    FROM CUST_INFO ;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    4.SUBSTR(字符分割函数)

    字段分隔

    SELECT SUBSTR(CUST_NAME,0,2) FROM CUST_BASE cb 
    
    • 1

    5.listagg

    将下面的转化为“篮球,乒乓球,羽毛球,足球”
    在这里插入图片描述

    SELECT listagg(hoppy,',') within group ( order by hoppy)
    FROM (
    SELECT DISTINCT (hoppy) FROM  user WHERE name='谷咕咕'
    )
    
    
    • 1
    • 2
    • 3
    • 4
    • 5

    listagg(measure_expr,delimiter) within group ( order by order_by_clause);

    解释:measure_expr可以是基于任何列的表达式

    delimiter分隔符,默认为NULL

    order_by_clause决定了列值的拼接顺序

    6.instr(字符查找函数)

    格式一:instr( string1, string2 ) // instr(源字符串, 目标字符串)

    格式二:instr( string1, string2 [, start_position [, nth_appearance ] ] ) // instr(源字符串, 目标字符串, 起始位置, 匹配序号)

    7.to_char(字符格式化)

    SELECT TO_CHAR(CREATE_DATE,'yyyy/MM/dd')  FROM CUST_BASE cb 
    
    • 1

    详细用法
    https://www.cnblogs.com/yuan88008/p/15597988.html

    8.to_number(转数字)

  • 相关阅读:
    【HCIA】华为 VRP 命令行基础
    Real-Time Rendering——10.1 Area Light Sources区域光源
    产品经理想升职加薪?这个证书你考了吗?
    opencv编译错误记录
    影视行业应该如何利用软文进行宣传?媒介盒子告诉你
    Collection体系集合
    二、字符串 String
    postman出现Required request part ‘file‘ is not present
    产品代码都给你看了,可别再说不会DDD(六):聚合根与资源库
    一体机电脑辐射超标整改
  • 原文地址:https://blog.csdn.net/a1424261303/article/details/126467646