postgresql case when then else end的用法

case when用法

基本语法:
select case A when B then C else D end E from table
A可以为表中的字段名或者是子查询,总之A是一个表达式
B是表达式的结果,如果A的查询结果等于B,则结果是C,否则是D
E是结果的查询别名,自己定义

多个条件判断
从表中取zpid,zhid(别名 zt)

if(zhid=='CS1'){
zt='1'
} else if(zhid=='zhid01'){
zt='2'
}else{
zt='3'
}

其中else的部分可以省略

包含子查询的例子

SELECT a.xxmc, a.xxbh,
case (select sjtzzbh from la.tzzxx where tzzbh=a.tzzbh) 
when '01' then 1 else 0 end sfssgx
from table a

case when的变形用法,单个表达式含有多个判定条件

可以将判定表达式放到when之后,需要该表达式是一个boolean类型的表达式

	select case   when zhid='cc'  then 1 else 0 end as sfpj 
	from lapos.jygw_pjdf ;

case when 后面也可以接多个判定条件,用and或者or 表示条件成立的“与”或者“或“

	select case   when zhid='cc' and tdid='td01' 
	then 1 else 0 end as sfpj 
	from lapos.jygw_pjdf ;
  • 9
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值