首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

SQL中的行转列和转行

而在SQL面试中,一道出镜频率很高的题目就是行转列和转行的问题,可以说这也是一道经典的SQL题目,本文就这一问题做以介绍分享。 ? 给定如下模拟数据集,这也是SQL领域经典的学生成绩表问题。...scoreWide 考察的问题就是通过SQL语句实现在这两种形态间转换,其中长表转为宽表即行转列,宽表转为长表即转行。...其基本的思路是这样的: 在长表的数据组织结构中,同一uid对应了多行,即每门课程一条记录,对应一组分数,而在宽表中需要将其变成同一uid下仅对应一行 在长表中,仅有一记录了课程成绩,但在宽表中则每门课作为一记录成绩...由多行变一行,那么直觉想到的就是要groupby聚合;由一变多,那么就涉及到衍生提取; 既然要用groupby聚合,那么就涉及到将多门课的成绩汇总,但现在需要的不是所有成绩汇总,而仍然是各门课的独立成绩...02 转行:union 转行是上述过程的逆过程,所以其思路也比较直观: 行记录由一行变为多行,字段由多变为单列; 一行变多行需要复制,字段由多变单列相当于是堆积的过程,其实也可以看做是复制;

6.9K30

Kettle使用_27 行转列与转行方法汇总

Kettle使用_27 行转列与转行方法汇总 大家好,我是架构君,一个会写代码吟诗的架构师。...今天说一说Kettle使用_27 行转列与转行方法汇总,希望能够帮助大家进步!!!                                      ...Kettle使用_27 行转列与转行方法汇总 需求:通过kettle实现行列转换与转行。 解决方法:主要通过排序记录、行专列、转行、行扁平化组件解决。...Step4:拖个转行(实际是行转列),该组件位于转换的转换分类下。通过SHIFT连接排序组件与当前组件,并配置行转列组件。 配置如下: Step5:拖个文本文件输出,该组件位于转换的输出分类下。...: 执行结果: 场景二(合并列)之方法四(通过聚合函数),数据和配置见下: 行转列(聚合函数方式配置): 执行结果; 场景三,转行: 这里拖个转行组件(该组件位于转换的转换分类下),并配置见下

2.3K20

mysql行转列简单例子_mysql行转列、转行示例

最近在开发过程中遇到问题,需要将数据库中一张表信息进行行转列操作,再将每(即每个字段)作为与其他表进行联表查询的字段进行显示。 借此机会,在网上查阅了相关方法,现总结出一种比较简单易懂的方法备用。...一、行转列:将原本同一下多行的不同内容作为多个字段,输出对应内容。...效果图: 数据库表中的内容: 转换后: 可以看出,这里行转列是将原来的f_subject字段的多行内容选出来,作为结果集中的不同,并根据f_student_id进行分组显示对应的f_score;...’语文’,f_score,0)作为条件,即对所有f_subject=’语文’的记录的f_score字段进行SUM()、MAX()、MIN()、AVG()操作,如果f_score没有值则默认为0; 二、转行

4.6K10
领券