行列互换问题,怎么办?送你一个万能模版

简介:

【题目】

下面是表名为cook的表

要求查询结果如下:

【解题思路】

电影《女男变错身》中是男女互换身份

这个题其实也是“互换身份”,叫做行列互换问题,就是将一维表转化为二维表。

1.输出行列互换的表结构

可以看出,需要输出的有5列,其中只有“年”这一列是表cook中原有的,其他4列(也就是2-5列:m1对应的是1月份、m2对应的是2月份、m3对应的是3月份、m4对应的是4月份)需要自己创建。

select 年,m1,m2,m3,m4
from cook;

可以看出查询结果和目标表的列名结构一样,但是2-5列(m1、m2、m3、m4)的值不是题目要求的:

  1. 如何将2-5列的值替换成对应的值?

可以用case语句进行条件判断来替换。

年份和月份匹配,则为对应值,不匹配则为0。

select 年,
(case 月 when '1' then 值 else 0 end) as m1,
(case 月 when '2' then 值 else 0 end) as m2,
(case 月 when '3' then 值 else 0 end) as m3,
(case 月 when '4' then 值 else 0 end) as m4
from cook;

select 年,
max(case 月 when '1' then 值 else 0 end) as 'm1',
max(case 月 when '2' then 值 else 0 end) as 'm2',
max(case 月 when '3' then 值 else 0 end) as 'm3',
max(case 月 when '4' then 值 else 0 end) as 'm4'
from cook
group by 年;

这个sql的运行过程如下:

这样我们就得到了目标表(行列互换)。

【本题考点】

1.考查用case语句进行数据替换,和条件判断

2.遇到行列互换的问题,可以用下面的万能模版来解决。

select A,
-- 第2步,在行列互换结果表中,其他列里的值分别使用case和max来获取
max(case B when 'm' then C else 0 end) as 'm',
max(case B when 'n' then C else 0 end) as 'n'
from cook
-- 第1步,在行列互换结果表中按第1列分组
group by A;

【举一反三】

下面是学生的成绩表(表名:成绩表,列名:学号,课程,成绩)

使用sql语句实现将该表行转化为下面的表结构:

参考答案:

select 学号,
-- 第2步,在行列互换结果表中,其他列里的值分别使用case和max来获取
max(case 课程 when '语文' then 成绩 else 0 end) as 语文成绩,
max(case 课程 when '数学' then 成绩 else 0 end) as 数学成绩
from 成绩表
-- 第1步,在行列互换结果表中按第1列分组
group by 学号;

输出结果:

推荐:如何从零学会sql?

相关文章
|
6月前
|
计算机视觉 索引
扫雷-包含空白展开,标记功能,游戏界面优化-控制台全力复刻
扫雷-包含空白展开,标记功能,游戏界面优化-控制台全力复刻
|
前端开发
前端学习笔记202305学习笔记第二十八天-数组结构之列表拖拽改变顺序4
前端学习笔记202305学习笔记第二十八天-数组结构之列表拖拽改变顺序4
43 0
|
6月前
|
XML JavaScript 前端开发
使用 doscify 将文章写成文档一般丝滑
使用 doscify 将文章写成文档一般丝滑
128 0
|
前端开发
前端学习笔记202305学习笔记第二十八天-数组结构之列表拖拽改变顺序3
前端学习笔记202305学习笔记第二十八天-数组结构之列表拖拽改变顺序3
55 0
|
前端开发
前端学习笔记202305学习笔记第二十八天-数组结构之列表拖拽改变顺序1
前端学习笔记202305学习笔记第二十八天-数组结构之列表拖拽改变顺序1
44 0
|
前端开发
前端学习笔记202305学习笔记第二十八天-数组结构之列表拖拽改变顺序2
前端学习笔记202305学习笔记第二十八天-数组结构之列表拖拽改变顺序2
55 0
|
机器学习/深度学习 搜索推荐 算法
编程艺术 - 第二章 、俩个字符串是否包含问题以及扩展
编程艺术 - 第二章 、俩个字符串是否包含问题以及扩展
69 0
|
JSON 数据格式
六种方式实现数组扁平化,总有一个适合你
扁平化在日常的工作中我们也会经常用到,也是面试时经常考的一道题,今天总结一下常见和不常见的数组扁平化的几种方式 数组的扁平化其实就是将一个嵌套多层的数组 array(嵌套可以是任何层数)转换为只有一层的数组。其实就是把多维的数组“拍平”,输出最后的一维数组。
194 0
|
前端开发
前端工作总结114-动态渲染数据 数据在数字字典里面
前端工作总结114-动态渲染数据 数据在数字字典里面
104 0
前端工作总结114-动态渲染数据 数据在数字字典里面
|
前端开发
前端工作总结116-动态渲染数据 数据在数字字典里面
前端工作总结116-动态渲染数据 数据在数字字典里面
96 0