zoukankan      html  css  js  c++  java
  • MSSQL行专列

     1 例一:
    2
    3 问题:假设有张学生成绩表(tb)如下:
    4 姓名 课程 分数
    5 张三 语文 74
    6 张三 数学 83
    7 张三 物理 93
    8 李四 语文 74
    9 李四 数学 84
    10 李四 物理 94
    11 想变成(得到如下结果):
    12 姓名 语文 数学 物理
    13 ---- ---- ---- ----
    14 李四 74 84 94
    15 张三 74 83 93
    16 答案:
    17 if object_id('tb')is not null drop table tb;
    18 create table tb(姓名varchar(10) , 课程varchar(10) , 分数int)
    19
    20 insert into tb values('张三' , '语文' , 74)
    21 insert into tb values('张三' , '数学' , 83)
    22 insert into tb values('张三' , '物理' , 93)
    23 insert into tb values('李四' , '语文' , 74)
    24 insert into tb values('李四' , '数学' , 84)
    25 insert into tb values('李四' , '物理' , 94)
    26 -- SQL SERVER 2000 静态SQL。
    27 指课程只有语文、数学、物理这三门课程。(以下同)
    28 select 姓名as 姓名,
    29 max(case 课程when '语文' then 分数else 0 end) 语文,
    30 max(case 课程when '数学' then 分数else 0 end) 数学,
    31 max(case 课程when '物理' then 分数else 0 end) 物理
    32 from tb
    33 group by 姓名
    34 -- 利用函数:pivot()SQL2005。
    35 SELECT *
    36 FROM tb PIVOT ( SUM(分数) FOR [课程] IN ( 语文, 数学, 物理) ) AS P
    37 -- SQL SERVER 2000 动态SQL。
    38 指课程不止语文、数学、物理这三门课程。(以下同、通用代码)
    39 declare @sql varchar(8000)
    40 set @sql = 'select 姓名'
    41 select @sql = @sql + ' , max( case 课程 when ''' + 课程+ ''' then 分数 else 0 end) as [' + 课程+ ']'
    42 from (select distinct 课程 from tb) as a
    43 set @sql = @sql + ' from tb group by 姓名'
    44 exec(@sql)
    45 /*
    46 姓名 数学物理语文
    47 李四 84 94 74
    48 张三 83 93 74*/
    49 -- SQL SERVER 2005 静态SQL。
    50 select * from (select * from tb) a pivot (max(分数) for 课程in (语文,数学,物理)) b
    51 -- SQL SERVER 2005 动态SQL。
    52 declare @sql varchar(8000)
    53 select @sql = isnull(@sql + ',' , '') + 课程 from tb group by 课程
    54 exec ('select * from (select * from tb) a pivot (max(分数) for 课程in (' + @sql + ')) b')
    55 方法 2
    56 declare @s nvarchar(4000)
    57 set @s=''
    58 Select @s=@s+','+quotename([课程])+'=max(case when [课程]='+quotename([课程],'''')+' then [分数] end)'
    59 from tb group by课程
    60 exec('select '+@s+' from tb ')


     

  • 相关阅读:
    区别@ControllerAdvice 和@RestControllerAdvice
    Cannot determine embedded database driver class for database type NONE
    使用HttpClient 发送 GET、POST、PUT、Delete请求及文件上传
    Markdown语法笔记
    Property 'sqlSessionFactory' or 'sqlSessionTemplate' are required
    Mysql 查看连接数,状态 最大并发数(赞)
    OncePerRequestFilter的作用
    java连接MySql数据库 zeroDateTimeBehavior
    Intellij IDEA 安装lombok及使用详解
    ps -ef |grep xxx 输出的具体含义
  • 原文地址:https://www.cnblogs.com/lilwzca/p/2253045.html
Copyright © 2011-2022 走看看