sql 行转列分析 以后再也不用记了

--SQL SERVER 2000静态SQL。

SELECT * FROM

(

SELECT 姓名,课程='语文',分数=语文 FROM tb

UNION ALL

SELECT 姓名,课程='数学',分数=数学 FROM tb

UNION ALL

SELECT 姓名,课程='物理',分数=物理 FROM tb

) t

ORDER BY 姓名,CASE 课程 WHEN '语文' THEN 1 WHEN '数学' THEN 2 WHEN '物理' THEN 3 end

 

 

 

 

 

表scores

 

请转成的横表是这样子的:

 

//

::::我们来分析下:首先 姓名这一列肯定是不重复的姓名【重复也没办法了 这需求只能这样了】 因此 我们用group by 【姓名】 然后姓名这一列就有了 其它的三列也就是需要凑起来 对吧!!!! 我们切记。聚合函数就是只有一列的!!!这个特性正好被使用。嘿嘿 我们就用聚合函数 可以用 sum 呀  max  min 这些不都行吗!!!

对了 这里对于【重复姓名】咱们不管哈 否则这样想想好像有问题!!!

 

select 姓名,
SUM(case 课程 when '语文' then 分数 else 0 end) as 语文,
SUM(case 课程 when '数学' then 分数 else 0 end) as 数学,
SUM(case 课程 when '物理' then 分数 else 0 end) as 物理
from scores group by 姓名


--延伸 select id,max(case when saleBill=222 then 222 end ) from ChuKuBill group by id 这里没有else 则默认的else 为null 

 

:::反过来 要把横表变成上面的一列一列的表怎么办呢?我们分析列表只有三列 对吧!!效果是相当于把【张三+语文+分数;张三+数学+分数。。】+【李四+语文+分数;李四+数学+分数。。】  一列一列叠起来的情况:我们有union和union all 解决 区别是 union会去重 我们这里就不让它去重了哈 【去重也无所谓  两列不可能都相同】

分析下表头 表头不存在我们用AS别名出来  总体看下来就是 select 姓名,'语文' as 课程,语文 as 分数 对吧!! 张三的语文成绩出来了 如法炮制 张三的数学成绩 最后联合李四的 

 

select 姓名,
'语文' as 课程,
语文 as 分数
from scores2
union all
select 姓名,
'数学' as 课程,
数学 as 分数
from scores2
union all
select 姓名,
'物理' as 课程,
物理 as 分数
from scores2
order by 姓名 desc  【这个有问题2019.10.28】

答案;

select 姓名,
SUM(case 课程 when '语文' then 分数 else 0 end) as 语文,
SUM(case 课程 when '数学' then 分数 else 0 end) as 数学,
SUM(case 课程 when '物理' then 分数 else 0 end) as 物理

---------------------

posted on 2019-10-28 22:43  代码小王子来了  阅读(288)  评论(0编辑  收藏  举报