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

时间:2023-01-08 09:59:05

目标:如果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;

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

【Teradata SQL】一个字段为空即取另外一个字段(连续取4个字段)-case when的更多相关文章

  1. Django数据库设计中字段为空的方式

    今天在做数据库设计的时候,设计了如下User表,其中我把email和phone字段设置为允许为空: class User(models.Model): username = models.CharFi ...

  2. oracle中使用sql查询时字段为空则赋值默认

    转至:http://www.th7.cn/db/Oracle/201501/86125.shtml oracle 通过 nvl( )函数sql 查询时为 空值 赋默认值 oracle 函数介绍之nvl ...

  3. 解决用 VB 中用 ADO 访问 数据库时 SQL 查询处理 Null 值的问题( 使用 iff&lpar;isNull&lpar;字段&rpar;&comma; 为空时的值,不为空时的值&rpar; 来处理)

    程序的环境是 VB6 + ADO + Access,在用 SQL 语句查询时,希望把两个字段合并成一个字段,但其中一个字段 Null 值直接导致两个字段合并后也变成了 Null 值.之前只能用 VB ...

  4. oracle判断一个字段为空

    比如 insert into table a (a1,b1)values("a1",''); 对于这种情况,因为表里存的是'',其实是没有内容的,要查询这个字段,不能直接使用 se ...

  5. 字段为空sql语句,设置当前模式

    delete from t_corpinfo  where CORPID='' and CORPNAME=''  该命令是删除字段为空的记录 SET CURRENT SCHEMA DB2INST1;

  6. PL&sol;SQL中判断字段为空

    功能写完发现数据库里好多关键字段是空的,可以直接删掉,可直接: DELETE FROM 表名 WHERE 字段 IS NULL OR TRIM(字段) = ''

  7. SQL点滴10—使用with语句来写一个稍微复杂sql语句,附加和子查询的性能对比

    原文:SQL点滴10-使用with语句来写一个稍微复杂sql语句,附加和子查询的性能对比 今天偶尔看到sql中也有with关键字,好歹也写了几年的sql语句,居然第一次接触,无知啊.看了一位博主的文章 ...

  8. in条件后面有多个字段,in后面只能有一个字段 Operand should contain 1 column&lpar;s&rpar;

    今天在sql测试的时候发现了这个错误:Operand should contain 1 column(s). 原因是in条件后面有多个字段,in后面只能有一个字段.

  9. Sql Server 中将由逗号&OpenCurlyDoubleQuote;,”分割的一个字符串转换为一个表集,并应用到 in 条件中

    Sql Server 中将由逗号“,”分割的一个字符串,转换为一个表,并应用与 in 条件 ,,) 这样的语句和常用,但是如果in 后面的 1,2,3是变量怎么办呢,一般会用字符串连接的方式构造sql ...

随机推荐

  1. MySQL InnoDB表--BTree基本数据结构

    MySQL InnoDB表是索引组织表这一点应该是每一个学习MySQL的人都会首先学到的知识,这代表这表中的数据是按照主键顺序存储,也就是说BTree的叶子节点存储了所有该行的数据. 我最开始是搞Or ...

  2. PAT——乙级真题1001代码

  3. 漫谈python中的搜索&sol;排序

    在数据结构那一块,搜索有顺序查找/二分查找/hash查找,而排序有冒泡排序/选择排序/插入排序/归并排序/快速排序.如果遇到数据量和数组排列方式不同,基于时间复杂度的考虑,可能需要用到混合算法.如果用 ...

  4. Oracle PL&sol;SQL 多重选择句

    Oracle中语句块的基本格式: declare --变量定义,初始化赋值. begin --变量的赋值,函数调用,if,while等. end: Oracle中的语句:关系运算符:= <&gt ...

  5. Permutations II ——LeetCode

    Given a collection of numbers that might contain duplicates, return all possible unique permutations ...

  6. 参数传递方法(Delphi1&period;0与win16API使用pascal方法,即从左到右)

    参数传递方法李维的InsideVCL<第一章>中提到Windows定义的回调函数typedef LRESULT (CALLBACK*WNDPROC)(HWND,UNIT,WPARAM,LP ...

  7. C&plus;&plus;虚函数表调用学习

    知识点是看 陈皓大哥的博客,代码也参考了他的,不过做了很小的改动. 原文链接:http://blog.csdn.net/haoel/article/details/1948051 #include & ...

  8. Servlet 中为多项选择题判分---String类的indexOf&lpar;&rpar;方法妙用

    首先来看一下String类的indexOf()方法的用法: public class FirstDemo1 { /** *API中String的常用方法 */ // 查找指定字符串是否存在 publi ...

  9. Intellj Idea使用tomcat部署不成功,死活也找不到解决办法的看这里

    Intellij 周六晚上开发一个简单web项目的,使用tomcat打包部署,死活也没法部署成功,和这个问题怼了6个小时,也没搞清楚具体为什么不能访问页面,但是好在最后还是找了个方法把问题解决了.以下 ...

  10. &lbrack;Swift&rsqb;LeetCode903&period; DI 序列的有效排列 &vert; Valid Permutations for DI Sequence

    We are given S, a length n string of characters from the set {'D', 'I'}. (These letters stand for &q ...