原文:在论坛中出现的比较难的sql问题:6(动态行转列 考试科目、排名动态列问题)

所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路。

下面的几个问题,都是动态行转列的问题。

数据查询,行转列的问题。

http://bbs.csdn.net/topics/390621630?page=1#post-395855019

根据数据查询得到如下数据表(tab):

班级           学号     姓名        科目             得分          班排名       校排名         标准分

ClassName  Code  Name  SubjectName TotalScore ClassRank SchoolRank TValue

201班        101     张三      语文               95             1                 1           700

201班        102     李四      语文               83             2                 3           600

202班        201     张飞      语文               85             1                 2           700

202班        202     赵云      语文               75             2                 4           600

201班        101     张三      数学               83             2                 2           600

201班        102     李四      数学               85             1                 3           700

202班        201     张飞      数学               95             1                 1           700

202班        202     赵云      数学               80             2                 4           600

需要得到如下数据:

班级           学号     姓名    语文   得分  班排名  校排名  标准分 数学   得分  班排名    校排名    标准分

201班        101     张三      语文     95       1        1       700       数学    83        2                 2           600

201班        102     李四      语文     83       2        3       600       数学    85        1                 3           700

202班        201     张飞      语文     85       1        2       700       数学    95        1                 1           700

202班        202     赵云      语文     75       2        4       600       数学    80        2                 4           600

真心求SQL,或者实现方法。

科目是动态的。能实现静态转换也行。

真心谢谢。

我的解法:


  1. if object_id('tab') is not null drop table tab
  2. go
  3. create table tab
  4. (
  5. [班级] varchar(9),[学号] varchar(4),[姓名] varchar(4),
  6. [科目] varchar(11),[得分] varchar(10),[班排名] varchar(9),
  7. [校排名] varchar(10),[标准分] varchar(6)
  8. )
  9. insert tab
  10. select '201班','101','张三','语文','95','1','1','700' union all
  11. select '201班','102','李四','语文','83','2','3','600' union all
  12. select '202班','201','张飞','语文','85','1','2','700' union all
  13. select '202班','202','赵云','语文','75','2','4','600' union all
  14. select '201班','101','张三','数学','83','2','2','600' union all
  15. select '201班','102','李四','数学','85','1','3','700' union all
  16. select '202班','201','张飞','数学','95','1','1','700' union all
  17. select '202班','202','赵云','数学','80','2','4','600'
  18. --------------开始查询--------------------------
  19. declare @sql nvarchar(3000);
  20. set @sql = '';
  21. select @sql =
  22. @sql + ',min(case when 科目=''' + 科目 + ''' then 科目 else null end) as ['+科目+ ']'+
  23. ',min(case when 科目=''' + 科目 + ''' then 得分 else null end) as 得分' +
  24. ',min(case when 科目=''' + 科目 + ''' then 班排名 else null end) as 班排名'+
  25. ',min(case when 科目=''' + 科目 + ''' then 校排名 else null end) as 校排名'+
  26. ',min(case when 科目=''' + 科目 + ''' then 标准分 else null end) as 标准分'
  27. from tab
  28. group by 科目
  29. order by 科目 desc
  30. select @sql = 'select 班级,学号,姓名'+@sql +
  31. ' from tab group by 班级,学号,姓名'
  32. select @sql
  33. exec(@sql)
  34. /*
  35. 班级 学号 姓名 语文 得分 班排名 校排名 标准分 数学 得分 班排名 校排名 标准分
  36. --------- ---- ---- ----------- ---------- --------- ---------- ------ ----------- ---------- --------- ---------- ------
  37. 201班 101 张三 语文 95 1 1 700 数学 83 2 2 600
  38. 201班 102 李四 语文 83 2 3 600 数学 85 1 3 700
  39. 202班 201 张飞 语文 85 1 2 700 数学 95 1 1 700
  40. 202班 202 赵云 语文 75 2 4 600 数学 80 2 4 600
  41. 警告: 聚合或其他 SET 操作消除了 Null 值。
  42. */


上面语句,产生的动态语句:

  1. select 班级,学号,姓名,
  2. min(case when 科目='语文' then 科目 else null end) as [语文],
  3. min(case when 科目='语文' then 得分 else null end) as 得分,
  4. min(case when 科目='语文' then 班排名 else null end) as 班排名,
  5. min(case when 科目='语文' then 校排名 else null end) as 校排名,
  6. min(case when 科目='语文' then 标准分 else null end) as 标准分,
  7. min(case when 科目='数学' then 科目 else null end) as [数学],
  8. min(case when 科目='数学' then 得分 else null end) as 得分,
  9. min(case when 科目='数学' then 班排名 else null end) as 班排名,
  10. min(case when 科目='数学' then 校排名 else null end) as 校排名,
  11. min(case when 科目='数学' then 标准分 else null end) as 标准分
  12. from tab
  13. group by 班级,学号,姓名

在论坛中出现的比较难的sql问题:6(动态行转列 考试科目、排名动态列问题)的更多相关文章

  1. 在论坛中出现的比较难的sql问题:46(日期条件出现的奇怪问题)

    原文:在论坛中出现的比较难的sql问题:46(日期条件出现的奇怪问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉得有 ...

  2. 在论坛中出现的比较难的sql问题:45(用户在线登陆时间的小时、分钟计算问题)

    原文:在论坛中出现的比较难的sql问题:45(用户在线登陆时间的小时.分钟计算问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. ...

  3. 在论坛中出现的比较难的sql问题:44(触发器专题 明细表插入数据时调用主表对应的数据)

    原文:在论坛中出现的比较难的sql问题:44(触发器专题 明细表插入数据时调用主表对应的数据) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决 ...

  4. 在论坛中出现的比较难的sql问题:42(动态行转列 考勤时间动态列)

    原文:在论坛中出现的比较难的sql问题:42(动态行转列 考勤时间动态列) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.

  5. 在论坛中出现的比较难的sql问题:41(循环替换 循环替换关键字)

    原文:在论坛中出现的比较难的sql问题:41(循环替换 循环替换关键字) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.

  6. 在论坛中出现的比较难的sql问题:40(子查询 销售和历史库存)

    原文:在论坛中出现的比较难的sql问题:40(子查询 销售和历史库存) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉得有 ...

  7. 在论坛中出现的比较难的sql问题:39(动态行转列 动态日期列问题)

    原文:在论坛中出现的比较难的sql问题:39(动态行转列 动态日期列问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉 ...

  8. 在论坛中出现的比较难的sql问题:38(字符拆分 字符串检索问题)

    原文:在论坛中出现的比较难的sql问题:38(字符拆分 字符串检索问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉得 ...

  9. 在论坛中出现的比较难的sql问题:37(动态行转列 某一行数据转为列名)

    原文:在论坛中出现的比较难的sql问题:37(动态行转列 某一行数据转为列名) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.

  10. 在论坛中出现的比较难的sql问题:36(动态行转列 解析json格式字符串)

    原文:在论坛中出现的比较难的sql问题:36(动态行转列 解析json格式字符串) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.

随机推荐

  1. python笔记7 logging模块 hashlib模块 异常处理 datetime模块 shutil模块 xml模块(了解)

    logging模块 日志就是记录一些信息,方便查询或者辅助开发 记录文件,显示屏幕 低配日志, 只能写入文件或者屏幕输出 屏幕输出 import logging logging.debug('调试模式 ...

  2. springboot 之JPA

    1.添加pom.xml <?xml version="1.0" encoding="UTF-8"?> <project xmlns=" ...

  3. Qt 自定义信号SIGNAL

    emit toLine(lineQStr);connect(vcthread, SIGNAL(toLine(QString)), this, SLOT(appendText(QString)));

  4. 阶段5 3.微服务项目【学成在线】_day16 Spring Security Oauth2_05-SpringSecurityOauth2研究-搭建认证服务器

    3 Spring Security Oauth2研究 3.1 目标 本项目认证服务基于Spring Security Oauth2进行构建,并在其基础上作了一些扩展,采用JWT令牌机制,并自定 义了用 ...

  5. Java Web接入支付宝扫码付款API(使用SDK证书配置properties )

    一.支付宝当面付功能Demo 官方文档https://docs.open.alipay.com/194/106078/ ps:因为沙箱环境一经配置了证书公钥则无法重置 第一步下载项目SKD&D ...

  6. JS微信网页使用图片预览(放大缩小)

    前言 需求在微信网页中客户点击图片可进行预览放大缩小功能,网上找了各种js方式实现, 唯一的麻烦就是不兼容或者和项目框架不兼容 次函数只只用于部分客户端,否则会出现 WeixinJSBridge is ...

  7. MongoDB集群之分片技术应用 —— 学习笔记

    课程链接:https://www.imooc.com/learn/501 一.什么是分片? 分片:将数据进行2拆分,将数据水平的分散到不同的服务器上. 二.为什么要分片? 架构上:读写均衡.去中心化 ...

  8. sklearn.svc 参数

    sklearn.svc 参数 sklearn中的SVC函数是基于libsvm实现的,所以在参数设置上有很多相似的地方.(PS: libsvm中的二次规划问题的解决算法是SMO). 对于SVC函数的参数 ...

  9. 【VS开发】【miscellaneous】windows(64位)下使用curl命令

    windows(64位)下使用curl命令 Curl命令可以通过命令行的方式,执行Http请求.在Elasticsearch中有使用的场景,因此这里研究下如何在windows下执行curl命令. 工具 ...

  10. 【MySQL】IN 的学习,以及和 EXISTS的区别

    1. EXISTS 的语法 语法: EXISTS subquery 参数: subquery 是一个受限的 SELECT 语句 (不允许有 COMPUTE 子句和 INTO 关键字). 结果类型: B ...