行转列-列转行_查询

开发过程中常遇到行转列或是列转行的问题,即需要将数据库中一张表信息进行行转列操作,再将每列(即每个字段)作为与其他表进行联表查询的字段进行显示。

一、行转列:将原来同一列下多行的不同内容作为多个字段,输出对应内容

数据库表中的内容:

转换后:

解析:

  行转列是将原来的subject字段的多行内容选出来,作为结果集中的不同列,并根据code进行分组显示对应的score



mysql> select s.name 姓名,s.code 学号,

-> sum(if(e.subject=‘语文‘,e.score,0)) 语文成绩,

-> sum(if(e.subject=‘数学‘,e.score,0)) 数学成绩,

-> sum(if(e.subject=‘英语‘,e.score,0)) 英语成绩

-> from student s

-> left join exam e

-> on s.code=e.code

-> group by s.code;



  ①sum()函数是为了能够使用group by根据code进行分组,因为每一个student.code对应的exam.subject=‘语文‘的记录只有一条,所以sum()的值就等于对应那一条记录的exam.score的值。

  (正常情况下此记录都是只有一条,当然如果有多条的话,可以使用sum()、max()、avg()、min()等聚合函数也都可以达到行转列的效果)

  ②if(e.subject=‘语文‘,e.score,0)作为条件,即对所有经过group by s.code分组的e.subject=‘语文‘的记录的e.score字段进行SUM()、MAX()、MIN()、AVG()操作,如果e.score没有值则默认为0。

  (当然使用case when then作为条件进行信息提取也是OK的)

二、列转行:将sid的每个科目分数分散成一条记录显示

数据库中的表:

转换后:

解析:

使用union all将每个sname对应的多个科目的成绩的结果集加起来



mysql> select sname,sid,‘语文‘ as subject,语文 as score from transcript

-> union all

-> select sname,sid,‘数学‘ as subject,数学 as score from transcript

-> union all

-> select sname,sid,‘英语‘ as subject,英语 as score from transcript

-> order by sname;



UNION与UNION ALL的区别:

  1.对重复结果的处理:UNION会去掉重复记录,UNION ALL不会;

  2.对排序的处理:UNION会排序,UNION ALL只是简单地将两个结果集合并;

  3.效率方面的区别:因为UNION 会做去重和排序处理,因此效率比UNION ALL慢很多

时间: 2024-10-11 12:51:24

行转列-列转行_查询的相关文章

数据库 行转列 列转行详解

目录结构如下: 行转列 列转行 [一].行转列 1.1.初始测试数据 表结构:TEST_TB_GRADE create table TEST_TB_GRADE ( ID        NUMBER(10) not null, USER_NAME VARCHAR2(20 CHAR), COURSE    VARCHAR2(20 CHAR), SCORE     FLOAT ) [sql] view plaincopy create table TEST_TB_GRADE ( ID        N

Sql server 中将数据行转列列转行(二)

老规矩,先弄一波测试数据,数据填充代码没有什么意义,先折叠起来: /* 第一步:创建临时表结构 */ CREATE TABLE #Student --创建临时表 ( StuName nvarchar(20), --学生名称 Chinese int, Math int, English int ) DROP TABLE #Student --删除临时表 SELECT * FROM #Student --查询所有数据 INSERT INTO #Student(StuName,Chinese,Math

MSSQLServer 纵向表转横向表 横向表转纵向表 行转列 列转行

MSSQLServer 纵向表转横向表  横向表转纵向表 建表语句及插入数据语句: CREATE TABLE Test_y( [Name] [nchar](10) NULL, [Course] [nchar](10) NULL, [Grade] [int] NULL ) insert into Test_y values ('张三','语文',75); insert into Test_y values ('张三','数学',80); insert into Test_y values ('张三

Oracle 多行变一列的方法

多行变一列的方法有很多,觉得这个第一眼看懂了当时就用的这个办法. 情况是这样的.以下数据前几列是一样的,需要把VAT_VALUE_CHAR 的值放在同一行上. SELECT * FROM ps_vat_defaults defaults WHERE defaults.vat_driver = 'VAT_ENT_RGSTRN' AND defaults.vat_driver_key1 = 'AMB19' AND defaults.vat_driver_key2 = 'DEU' AND vat_de

行存储和列存储

传统的行式数据库将一个个完整的数据行存储在数据页中.这种方式在大数据量查询的时候会出现以下问题 1.在没有索引的情况下,会把一行全部查出来,查询会使用大量IO 2.虽然建立索引和物化视图可以可以快速定位列,但是也需要花费大量时间 但是如果处理查询时需要用到大部分的数据列,这种方式在磁盘IO上是比较高效的. 一般来说,OLTP(Online Transaction Processing,联机事务处理)应用适合采用这种方式. 一个OLAP类型的查询可能需要访问几百万甚至几十亿个数据行,且该查询往往只

如何获取ResultSet的行数和列数

当我们执行数据库查询返回一个ResultSet的时候,很多情况下我们需要知道这个ResultSet的大小,即它的行数和列数.我们知道它的列数可以通过resultSet.getMetaData().getColumnCount()很容易地得到,然而,java API没有提供直接访问ResultSet行数的接口. 这个时候,有三个办法可以解决: 1.改用select count语句,然后直接从ResultSet里面获取结果: try { Statement statement = connectio

地瓜君的excel小课堂——行函数与列函数

大家用Excel处理数据的时候经常会用到一些查找引用函数,今天地瓜君就来和大家一起学习一下查找引用函数中的行函数与列函数啦. 导航:1.row函数 2.rows函数 3.column函数 4.columns函数 我们重点介绍这4个函数里最常见也是非常实用的函数row函数,其他3个函数不是最常用所以就稍微简单的介绍下啦 一.row函数(返回一个引用的行号) 语法:=row(reference) 说明:如果省略reference(参数),则默认返回row函数所在单元格的行号. 参数reference

面向行与面向列

最近看到H5.H2.HBase的,以为有啥关联,后来知道H5->HTML5(很多人在吐槽这个缩写), H2 -> 一个内存数据库, HBase是一个分布式的.面向列的开源数据库. -.- 原谅我着急的智商,以我对数据库的了(shui)解(ping),我之前根本不知道”基于行“与”面向列“这样的概念..只知道SELECT\UPDATE\DELETE... 好吧,好好搜搜,找到这么一篇(H2与HBase)面向行or面向列的存储模型? 数据库的内部结构不敢多谈,因为不清楚.-.- 大体上是采用了B-

“ORA-06550: 第 1 行, 第 7 列”解决方法

将本机能正常运行的维修生产日志代码发布到公司内测环境里无法正常运行,报错如下: execute() - pls–QuartzJob.java–quartzjob 开始执行! java.sql.SQLException: ORA-06550: 第 1 行, 第 7 列: PLS-00201: identifier 'MONITORCHANGEPLS.MCP_ISCHANGE' must be declared ORA-06550: 第 1 行, 第 7 列: PL/SQL: Statement i