PostgreSQL函数的条件表达式

PostgreSQL函数的条件表达式

http://postgres.cn/docs/14/functions-conditional.html

CASE

SQL CASE表达式是一种通用的条件表达式。
支持两种写法,类似于其他编程语言的if/else和switch语句。

-- 写法1:类似于 if/else 语句。
CASE WHEN condition THEN result
     [WHEN ...]
     [ELSE result]
END

-- 写法2:类似于 switch 语句。
CASE expression
    WHEN value THEN result
    [WHEN ...]
    [ELSE result]
END

-- 用例1:
SELECT
CASE WHEN 1=2 THEN 't1'
WHEN 2=2 THEN 't2'
WHEN 3=2 THEN 't3'
ELSE 'te'
END

-- 用例2:
SELECT CASE 2
	WHEN 1 THEN 't1'
	WHEN 2 THEN 't2'
	WHEN 3 THEN 't3'
	ELSE 'te'
END CASE;
-- 输出:
t2

COALESCE

COALESCE函数返回它的第一个非空参数的值。当且仅当所有参数都为空时才会返回空。
它常用于在为显示目的检索数据时用缺省值替换空值。
迁移时Oracle的NVL方法,可以使用COALESCE和CASE方法达到类似效果替换。

COALESCE(value [, ...])

-- 用例:
SELECT 
COALESCE(NULL, NULL),
COALESCE(1, 2), 
COALESCE(1, NULL),
COALESCE(NULL, 2),
COALESCE(NULL, NULL, 3)
-- 输出:
<null>	1	1	2	3

NULLIF

当value1和value2相等时,NULLIF返回一个空值。 否则它返回value1。
这些可以用于执行前文给出的COALESCE例子的逆操作。

NULLIF(value1, value2)

-- 用例:
SELECT 
NULLIF(1, 1), 
NULLIF(NULL, NULL), 
NULLIF(1, NULL), 
NULLIF(NULL, 1)
-- 输出:
<null>	<null>	1	<null>

GREATEST和LEAST

GREATEST和LEAST函数从一个任意的数字表达式列表里选取最大或者最小的数值。
这些表达式必须都可以转换成一个普通的数据类型,它将会是结果类型。
列表中的 NULL 数值将被忽略。只有所有表达式的结果都是 NULL 的时候,结果才会是 NULL。

GREATEST(value [, ...])
LEAST(value [, ...])

-- 用例:
SELECT
GREATEST(1,8,3), 
LEAST(1,8,3)
-- 输出:
8	1

请注意GREATEST和LEAST都不是 SQL 标准,但却是很常见的扩展。
某些其他数据库让它们在任何参数为 NULL 时返回 NULL,而不是在所有参数都为 NULL 时才返回 NULL。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值