【SQL】行转列,列转行的意义

行列显示:只是以自己需要的角度去看待,觉得需要行的就行,列就列。行和列观看的维度是不一样的,列只能看到相同的字段下的,但是能看到所有行的,行能看到所有列的不同维度,但是只是一行数据。

 

列转行有个好处:可以把自己定义的列名, 比如as 字段1  as字段2, 全部转为行数据

 

行显示

 

好处:

  1. 如果列显示课程的话,课程太多,就有太多的字段要维护,要插入等
  2. 在sql直接pivot成列的样子看

缺点:

  1. 看起来,总结不方便

班级

姓名

课程

分数

1班

小王

英语

90

1班

小王

数学

99

1班

小王

语文

89

2班

小李

英语

77

 

列显示

优点:

  1. 显示方便
  2. 如果数据库是按列设计的,那看起来也方便,select出来看起来方便。
  3. 如果要和其他表join的话,用Unpivot好,是按班级和姓名group by的

缺点:

  1. 维护难

班级

姓名

英语

语文

语文

1班

小王

90

99

89

2班

小李

77

posted @ 2016-07-25 18:22  阿玛  阅读(1435)  评论(0)    收藏  举报