当前位置: 首页 > backend >正文

GaussDB case when的用法

1 case函数的类型


case具有两种格式,简单case函数和case搜索函数。这两种方式,大部分情况下可以实现相同的功能。

1.1 简单case函数语法


case column
when <condition> then value
when <condition> then value
......
else value end;

示例

case sex
when '1' then '男'
when '2' then '女'
else '其他' end;


1.2 case搜索函数语法


case
when <condition> [,<condition>] then value
when <condition> [,<condition>] then value
......
else value end;

示例

case

      when sex = '1' then '男'

     when sex = '2' then '女'

else '其他' end;


简单case 函数重在简洁,但是它只适用于这种单字段的单值比较,而case 搜索函数的优点在于适用于所有比较(包括多值比较)的情况。

例如:

CASEWHEN sex = '1' AND age>18 THEN '成年男性'WHEN sex = '2' AND age>18 THEN '成年女性'ELSE '其他' END;

注意:

CASE函数只返回第一个符合条件的值,剩下的CASE部分将会被自动忽略。比如说,下面这段SQL,你case when type in ('a','b') then '第一类' when type in ('a') then '第二类' else '其他类' end永远无法得到“第二类”这个结果。

2 case行转列

case用的比较广泛的功能就是行转列,就是将记录行里的数据按条件转换成具体的列。看如下的一个示例数据:

create table score(name varchar(10),course varchar(10),scott int);
insert into score values (n'张三',n'语文',74); 
insert into score values (n'张三',n'数学',83);
insert into score values (n'张三',n'物理',93);
insert into score values (n'李四',n'语文',74); 
insert into score values (n'李四',n'数学',84);
insert into score values (n'李四',n'物理',94);

现在我们想实现这样的功能,就是将各学科作为单独的列来显示各个学生各科的成绩。我们可以对课程里的记录做如下的行列转换:

select name, max(case course when '语文' then scott else 0 end) 语文, max(case course when '数学' then scott else 0 end) 数学,max(case course when '物理' then scott else 0 end) 物理 
from score 
group by name;

结果:

3 piovt函数行转列

如果要实现等同上面的结果:

select * from 
score pivot( max(scott) for course in ('语文','数学','物理')) a;

结果:

其中:

for后面的是我们即将进行行转列的列部分
in里面的是我们行转列之后的列
max是聚合IN里面的内容,也可以是其他聚合函数:SUM,MIN,COUNT等
piovt写法比较固定,是case when的一种简略写法。

4 批注

case是我们在日常工作中使用非常频繁的一个功能,可以很好的将我们需要的数据单独的显示在一列里面,有助于对数据有个比较清晰的掌握

http://www.xdnf.cn/news/16895.html

相关文章:

  • 在win上安装最新的X-anylabeling以及sam2来帮助进行全自动追踪标注
  • 多模态后训练反常识:长思维链SFT和RL的协同困境
  • Git 常用命令指南:从入门到高效开发
  • 【Qt】QObject::startTimer: Timers cannot be started from another thread
  • 考研复习-计算机组成原理-第二章-数据的表示和运算
  • Kazam产生.movie.mux后恢复视频为.mp4
  • 第三章-提示词-高级:开启智能交互新境界(13/36)
  • Steam饥荒联机版多人服务器搭建全解析 -- 阿里云Linux系统构建云服务器
  • MPLS LSP
  • Mysql深入学习:慢sql执行
  • C语言基础03——数组——习题
  • 时序论文44 | TwinsFormer:通过两个交互组件重构时间序列内在依赖关系
  • 14. 最长公共前缀
  • 8-verilog-串口接收与发送模块
  • docker 可用镜像列表(长期免费)
  • 嵌入式硬件篇---Openmv
  • Java 高频面试考点(下)
  • 【MySQL安全】什么是SQL注入,怎么避免这种攻击:前端防护、后端orm框架、数据库白名单
  • ELECTRICAL靶机
  • SQL157 更新记录(一)
  • Java企业级应用性能优化实战
  • ABAP SQL更新DB小技巧 WITH INDICATORS
  • W3D引擎游戏开发----从入门到精通【10】
  • 第二节 YOLOv5参数
  • 在 macOS 上通过 Docker 部署DM8 (ARM 架构)
  • 团队独立思考的力量
  • 2025-0803学习记录21——地表分类产品的精度验证
  • MySQL存储过程和触发器
  • 【网络安全】日志文件格式
  • 「源力觉醒 创作者计划」_文心大模型4.5系列开源模型, 从一行代码到一个生态:聊聊开源战略那些事儿,顺便扯扯文心大模型 4.5 的使用心得