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 语句。

posted @ 2021-12-07 08:51  数据库集中营  阅读(4121)  评论(0编辑  收藏  举报