SQL中的case when then else end用法

一种选择性sql函数:case when 是条件 then 是满足条件后的结果,当结果为null的时候,用else 后的0填充,end表示此函数结束。


SELECT "country",
	"SUM"(CASE "sex" WHEN 1 THEN "population" ELSE 0 END) 男,
	"SUM"(CASE "sex" WHEN 2 THEN "population" ELSE 0 END) 女
FROM "test12" GROUP BY "country"
<==> 等价于
SELECT "country",
  SUM( CASE WHEN "sex" = '1' THEN "population" ELSE 0 END) AS 男,  
  SUM( CASE WHEN "sex" = '2' THEN "population" ELSE 0 END) AS 女 
FROM  "test12" GROUP BY "country";

SELECT DISTINCT"test11"."id",AA."name",AA."数学",AA."英语",AA."语文" FROM(
select "name",
  max(case "kecheng" when '语文' then "score" else 0 end) 语文,
  max(case "kecheng" when '数学' then "score" else 0 end) 数学,
  max(case "kecheng" when '英语' then "score" else 0 end) 英语
from "test11"
GROUP BY "name"
) aa
INNER JOIN "test11" ON AA."name" = "test11"."name" ORDER BY "id"

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值