• 【Teradata SQL】一个字段为空即取另外一个字段(连续取4个字段)-case when


    目标:如果col1为空则取col2的值,如果col2也为空则取col3的值,如果col3还为则取col4的值,如果四个字段均为空则取默认值

    1.数据准备

    create multiset table test1 
    (
    col_type varchar(20),
    col1 varchar(10),
    col2 varchar(20),
    col3 varchar(30),
    col4 varchar(10)
    )no primary index;
    
    insert into test1 values ('fetch_col1','col1','col2','col3','clo4'); --字段均有值
    insert into test1 values ('fetch_col1','col1','','col3','clo4');--col2无值
    insert into test1 values ('fetch_col1','col1','col2','','clo4');--col3无值
    insert into test1 values ('fetch_col1','col1','col2','col3','');--col4无值
    
    insert into test1 values ('fetch_col2','','col2','col3','clo4');--col1无值
    insert into test1 values ('fetch_col2','','col2','','clo4');--col3无值
    insert into test1 values ('fetch_col2','','col2','col3','');--col4无值
    insert into test1 values ('fetch_col2','','col2','','');--仅col2有值,其余均无值
    
    insert into test1 values ('fetch_col3','','','col3','clo4');--col1和col2无值
    insert into test1 values ('fetch_col3','','','col3','');--仅col3有值,其余均无值
    
    insert into test1 values ('fetch_col4','','','','clo4');--仅col4有值,其余均无值
    
    insert into test1 values ('fetch_default','','','','');--全部无值

    2.查询结果

    sel 
    col_type,
    case 
       when col1 <>'' then col1 
       when col2 <> '' then col2
       when col3 <>'' then col3
       when col4 <>'' then col4
       else 'default'
    end fetch_value
    ,col1,col2,col3,col4
    from test1 order by 3 desc,4 desc,5 desc,6 desc;

  • 相关阅读:
    系统兼容性与软件兼容性
    SqlServer 笔记三 规则
    Sql Server 2008 与 Visual Studio 2008 安装说明
    Ms Sql Server
    Git系列教程三 配置与基本命令
    Git系列教程一 入门与简介
    Git系列教程二 基础介绍
    浏览器IE与非IE区分
    SqlServer 笔记二 获取汉字的拼音首字母
    时间戳与日期字符串的转换
  • 原文地址:https://www.cnblogs.com/badboy200800/p/10791305.html
Copyright © 2020-2023  润新知