postgresql中条件表达式 coalesce、nullif 、greatest、least
一、postgresql中条件表达式
1.1 GREATEST和LEAST
GREATEST(value [, ...])
LEAST(value [, ...])
# 注意比较值得类型一定要相同
案例:比较time1,time2, time3 三个时间大小
GREATEST和LEAST函数从一个任意的数字表达式列表里选取最大或者最小的数值。 这些表达式必须都可以转换成一个普通的数据类型,它将会是结果类型 (http://www.postgres.cn/docs/9.6/typeconv-union-case.html)。列表中的 NULL 数值将被忽略。只有所有表达式的结果都是 NULL 的时候,结果才会是 NULL。
请注意GREATEST和LEAST都不是 SQL 标准,但却是很常见的扩展。某些其他数据库让它们在任何参数为 NULL 时返回 NULL,而不是在所有参数都为 NULL 时才返回 NULL。
1.2 nullif
NULLIF(value1, value2)
当value1和value2相等时,NULLIF返回一个空值。 否则它返回value1。
1.3 COALESCE
COALESCE(value [, ...])
COALESCE函数返回它的第一个非空参数的值。当且仅当所有参数都为空时才会返回空。它常用于在为显示目的检索数据时用缺省值替换空值
1.4 case
SQL CASE表达式是一种通用的条件表达式,类似于其它编程语言中的 if/else 语句。
知识分享,需人人参与,看完请点赞留言,共同讨论进步