• 时间:2017-09-11 整理:byzqy

题目:有个年度统计表,结构如下:

怎么样把这个表,查询成这样一个结果:

这是在面试过程中遇到的一个关于数据库的题,没有一点思路,不知它考查到的知识点是什么,如何下手?

网上搜了一下,有哥们儿说这是典型的“行转列问题”,好像用到“交叉表查询”,下面看看具体的代码!

文件:SQLQuery1.sql

/*
环境:Microsoft SQL Server 2012
工具: Microsoft SQL Server Management Studio
数据库: Interview
数据表: statistic
详情:
year month amount
1991 1 1.1
1991 2 1.2
1991 3 1.3
1991 4 1.4
1992 1 2.1
1992 2 2.2
1992 3 2.3
1992 4 2.4
(char(10)) (int) (float)
查询成如下结果:
year m1 m2 m3 m4
1991 1.1 1.2 1.3 1.4
1992 2.1 2.2 2.3 2.4
*/ --方法1
SELECT
year,
SUM ( CASE WHEN month = 1 THEN amount ELSE 0 END ) AS m1,
SUM ( CASE WHEN month = 2 THEN amount ELSE 0 END ) AS m2,
SUM ( CASE WHEN month = 3 THEN amount ELSE 0 END ) AS m3,
SUM ( CASE WHEN month = 4 THEN amount ELSE 0 END ) AS m4
FROM
statistic
GROUP BY
year -->查询结果:
year m1 m2 m3 m4
1991 1.1 1.2 1.3 1.4
1992 2.1 2.2 2.3 2.4 --方法2
SELECT
year,
MAX(CASE month WHEN 1 THEN amount ELSE 0 END) m1,
MAX(CASE month WHEN 2 THEN amount ELSE 0 END) m2,
MAX(CASE month WHEN 3 THEN amount ELSE 0 END) m3,
MAX(CASE month WHEN 4 THEN amount ELSE 0 END) m4
FROM statistic
GROUP BY year -->查询结果:
year m1 m2 m3 m4
1991 1.1 1.2 1.3 1.4
1992 2.1 2.2 2.3 2.4 --方法3
SELECT year,
(SELECT amount FROM statistic m WHERE month=1 AND m.year=statistic.year) AS m1,
(SELECT amount FROM statistic m WHERE month=2 AND m.year=statistic.year) AS m2,
(SELECT amount FROM statistic m WHERE month=3 AND m.year=statistic.year) AS m3,
(SELECT amount FROM statistic m WHERE month=4 AND m.year=statistic.year) AS m4
FROM statistic GROUP BY year -->查询结果:
year m1 m2 m3 m4
1991 1.1 1.2 1.3 1.4
1992 2.1 2.2 2.3 2.4

运行结果:

代码分解:

--方法1变形:将代码中的0改为1,计算SUM,看看会发生什么
SELECT
year,
SUM ( CASE WHEN month = 1 THEN amount ELSE 1 END ) AS m1,
SUM ( CASE WHEN month = 2 THEN amount ELSE 1 END ) AS m2,
SUM ( CASE WHEN month = 3 THEN amount ELSE 1 END ) AS m3,
SUM ( CASE WHEN month = 4 THEN amount ELSE 1 END ) AS m4
FROM
statistic
GROUP BY
year -->查询结果:
year m1 m2 m3 m4
1991 4.1 4.2 4.3 4.4
1992 5.1 5.2 5.3 5.4 --方法2变形1:将MAX关键字换为MIN
SELECT
year,
MIN(CASE month WHEN 1 THEN amount ELSE 0 END) m1,
MIN(CASE month WHEN 2 THEN amount ELSE 0 END) m2,
MIN(CASE month WHEN 3 THEN amount ELSE 0 END) m3,
MIN(CASE month WHEN 4 THEN amount ELSE 0 END) m4
FROM statistic
GROUP BY year -->查询结果:
year m1 m2 m3 m4
1991 0 0 0 0
1992 0 0 0 0 --方法2变形2:将MAX关键字换为MIN,并将0换为1
SELECT
year,
MIN(CASE month WHEN 1 THEN amount ELSE 1 END) m1,
MIN(CASE month WHEN 2 THEN amount ELSE 1 END) m2,
MIN(CASE month WHEN 3 THEN amount ELSE 1 END) m3,
MIN(CASE month WHEN 4 THEN amount ELSE 1 END) m4
FROM statistic
GROUP BY year -->查询结果:
year m1 m2 m3 m4
1991 1 1 1 1
1992 1 1 1 1 --方法2变形3:将MAX关键字换为SUM,并将0换为1
SELECT
year,
SUM(CASE month WHEN 1 THEN amount ELSE 1 END) m1,
SUM(CASE month WHEN 2 THEN amount ELSE 1 END) m2,
SUM(CASE month WHEN 3 THEN amount ELSE 1 END) m3,
SUM(CASE month WHEN 4 THEN amount ELSE 1 END) m4
FROM statistic
GROUP BY year -->查询结果:
year m1 m2 m3 m4
1991 4.1 4.2 4.3 4.4
1992 5.1 5.2 5.3 5.4

以上整理,如有错误之处或有更好的方法,请看到朋友不吝指正,谢谢!

参考文章:

https://zhidao.baidu.com/question/550776347.html

https://zhidao.baidu.com/question/486996750.html

https://www.zybang.com/question/0ac74f3ae058071e80274e23d5e1042a.html

T-SQL - 习题02_将数据表year|month|amount查询成year|m1|m2|m3|m4的样式的更多相关文章

  1. Sql Server系列:数据表操作

    表是用来存储数据和操作数据的逻辑结构,用来组织和存储数据,关系数据库中的所有数据都表现为表的形式,数据表由行和列组成.SQL Server中的数据表分为临时表和永久表,临时表存储在tempdb系统数据 ...

  2. 使用Sql语句快速将数据表转换成实体类

    开发过程中经常需要根据数据表编写对应的实体类,下面是使用sql语句快速将数据表转换成对应实体类的代码,使用时只需要将第一行'TableName'引号里面的字母换成具体的表名称就行了: declare ...

  3. 【SQL Server】sql server更改了数据表的字段/新增数据表的字段 无法保存

    sql server更改了数据表的字段/新增数据表的字段  无法保存 解决方法:进入 工具-->选项-->Designers-->表设计器和数据库设计器-->取消勾选   即可

  4. 定制Asp.NET 5 MVC内建身份验证机制 - 基于自建SQL Server用户/角色数据表的表单身份验证

    背景 在需要进行表单认证的Asp.NET 5 MVC项目被创建后,往往需要根据项目的实际需求做一系列的工作对MVC 5内建的身份验证机制(Asp.NET Identity)进行扩展和定制: Asp.N ...

  5. Sql中如何将数据表的两个字段的值如何互换?

    今天遇到一个数据表的两个列数据要互换,在网上找到并记录下. 直接用Sql就可以搞定,语法如下 --将数据表中两个列数据互换的语法-- update tabName set field1=field2, ...

  6. C# 如何获取SQL Server 中指定数据表的所有字段名和字段类型

    如何获取指定数据表的所有字段名和字段类型.SqlConnection.GetSchema方法有2个重载形式,获取指定数据表的所有字段名和字段类型的秘密就在GetSchema (String, Stri ...

  7. sql server返回插入数据表的id,和插入时间

    假设要插入数据的数据表结构如下

  8. SQL第二课-创建数据表

    查看有多少数据库 SHOW DATABASES; 进入数据库:USE <数据库名> 举例:USE test;//进入test数据库 查看当前进入的是哪个数据库 SELECT DATABAS ...

  9. My SQL随记 003 数据表基础操作语法

    数据表 查看数据表 修改表名 修改字段名 修改字段数据类型 添加删除-字段 约束(主外键默认检查) 查看表结构: 语法:DESRIBE(描述) table_Name; DESC  table_Name ...

随机推荐

  1. 【每日算法】存在重复元素 II

    题目描述 这是 LeetCode 上的 219. 存在重复元素 II, 难度为 [简单] 给定一个整数数组和一个整数 k,判断数组中是否存在两个不同的索引 i 和 j,使得 nums [i] = nu ...

  2. 第2天 第一个程序&IDEA安装&Java基础语法

    第一个程序 Hello,World! 随便新建一个文件夹,存放代码 新建一个Java文件 文件后缀名为java Hello.java [注意点]系统可能没有显示后缀名,必须手动打开 编写代码 publ ...

  3. YGC问题排查

    在高并发下, Java程序的GC问题属于很典型的一类问题,带来的影响往往会被进一步放大. 不管是 「GC频率过快」还是「GC耗时太长」,由于GC期间都存在Stop The World问题,因此很容易导 ...

  4. 还在用Postman?来,花2分钟体验下ApiPost的魅力

    2分钟玩转APIPOST 本文通过简单介绍如何利用ApiPost调试接口和快速的生成接口文档,让您初步体验ApiPost的魅力! 1. API写完想要测试?试试模拟发送一次请求 新建接口,我想模拟发送 ...

  5. C语言中变参函数传参探究

    背景引入 近期在看一本书,叫做<嵌入式C语言自我修养>,写的内容对我帮助很大,是一本好书.在第6章,GNU C编译器扩展语法精讲一节,这本书给出了一些变参函数的例子: //1.变参函数初体 ...

  6. Apache解析漏洞

    多解析特性 在Apache1.x,2.x中Apache 解析文件的规则是从右到左开始判断解析,如果后缀名为不可识别文件解析,就再往左判断.因此对于apache而言,一个test.php.qwea文件依 ...

  7. 一定要弄懂GetMemory

    堆栈 栈中分配局部变量空间,是系统自动分配空间.定义一个 char a:系统会自动在栈上为其开辟空间.由于栈上的空间是自动分配自动回收的,所以栈上的数据的生存周期只是在函数的运行过程中,运行后就释放掉 ...

  8. 用expect做自动运行脚本

    下面的脚本演示了在Ubuntu上安装expect,写一个切换用户的expect脚本,并运行脚本看到效果的过程. root@guserver:~# apt-get install expect godu ...

  9. Golang语言系列-07-函数

    函数 函数的基本概念 package main import ( "fmt" ) // 函数 // 函数存在的意义:函数能够让代码结构更加清晰,更简洁,能够让代码复用 // 函数是 ...

  10. STM32—重定向printf和getchar函数到串口

    在STM32测试串口的时候经常需要在开发板和上位机之间传输数据,我们可以用c语言中的printf()函数和getchar()函数来简化传输. 以printf()为例: printf()函数实际上是一个 ...