mssql关于一个表格结构的另外一种显示(表达意思不变)

一、需求

  由于表达能力不好,直接上图。在mssql环境中需要把图1的表转化成图2的表:

             图1                 图2

二、分析

  

  图3

2.1创建表


代码如下:

create table #tb
(ID int primary key,
Class nvarchar(max),
[Subject] nvarchar(max),
Score int)
insert into #tb values(1,'一(1)班','语文','92')
insert into #tb values(2,'一(1)班','数学','91')
insert into #tb values(3,'一(1)班','英语','93')
insert into #tb values(4,'一(2)班','数学','94')
insert into #tb values(5,'一(2)班','语文','95')
insert into #tb values(6,'一(2)班','英语','96')
insert into #tb values(7,'一(3)班','数学','94')
insert into #tb values(8,'一(3)班','语文','96')
insert into #tb values(9,'一(3)班','英语','97')
select * from #tb

2.2把图3中的第一张表转化为第二张表


代码如下:

select [Subject], [一(1)班]=[Score]
,[一(2)班]=[Score]
,[一(3)班]=[Score]
from #tb

2.3把图3中的第二张表转化为第三张表


代码如下:

--观察第二张表,表显然很多成绩是错误的,所以要消除错误

--消除错误的方法:先把错误的成绩设置为0,然后每一行取最大的数作为成绩,并按照科目来分组显示
select subject,[一(1)班]=case when [Class]='一(1)班' then [Score] else 0 end
,[一(2)班]= case when [Class]='一(2)班' then [Score] else 0 end
,[一(3)班]=case when [Class]='一(3)班' then [Score] else 0 end
from #tb

2.4 把图3中的第三张表转化为第四张表


代码如下:

select subject, [一(1)班]=max( case when [Class]='一(1)班' then [Score] else 0 end)
,[一(2)班]=max( case when [Class]='一(2)班' then [Score] else 0 end)
,[一(3)班]=max( case when [Class]='一(3)班' then [Score] else 0 end)
from #tb group by subject

2.5简化上面的写法


代码如下:

declare @s nvarchar(4000)
set @s=''
Select @s=@s+','+quotename(Class)+'=max( case when [Class]='+quotename(Class,'''')+' then [Score] else 0 end)'
from #tb group by Class
--print @s
exec('select [Subject]'+@s+' from #tb group by [Subject]')

三、简化分析和需求延伸

3.1简化分析

  上面的简化,对于菜鸟级的我,理解着还是非常吃力的,所以我是在知道答案后,用 print @s一步一步的去分析的,特别是在select @s=@s+.....的时间,在这里我找到了一种把单列数据连接成字符串的方法。

图4

3.2需求延伸

  或许上面的需求太简单,那么我们现在引出复杂点的需求,动态获取班级的成绩,比如我们的需求可能是列出部分班级的成绩,代码如下:


代码如下:

declare @s nvarchar(4000)
set @s=''
Select @s=@s+','+quotename(Class)+'=max( case when [Class]='+quotename(Class,'''')+' then [Score] else 0 end)'
from #tb
where Class in(你想要的班级)
group by Class
--print @s
exec('select [Subject]'+@s+' from #tb group by [Subject]')

四、总结

  本文主要实现表的另外一种显示,通常用于动态显示数据的例子中。难点在于分析过程和一些基本的sql语法。

(0)

相关推荐

  • mssql关于一个表格结构的另外一种显示(表达意思不变)

    一.需求 由于表达能力不好,直接上图.在mssql环境中需要把图1的表转化成图2的表:              图1                 图2 二.分析 图3 2.1创建表 复制代码 代码如下: create table #tb (ID int primary key, Class nvarchar(max), [Subject] nvarchar(max), Score int) insert into #tb values(1,'一(1)班','语文','92') insert

  • AngularJS中的Directive自定义一个表格

    先给大家说下表格的需求: ● 表格结构 <table> <thead> <tr> <th>Name</th> <th>Street</th> <th>Age</th> </tr> </thead> <tbody> <tr> <td>></td> <td>></td> <td>>

  • 完美解决UI-Grid表格元素中多个空格显示为一个空格的问题

    UI-Grid中表格数据中如果存在多个连续的空格,会显示为一个空格,解决方法很简单,只需要加上这样一个样式: .ui-grid-cell-contents { white-space: pre !important; } white-space 属性设置如何处理元素内的空白. pre:  空白会被浏览器保留.其行为方式类似 HTML 中的 <pre> 标签. 以上这篇完美解决UI-Grid表格元素中多个空格显示为一个空格的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多

  • 通过js脚本复制网页上的一个表格的不错实现方法

    今天有人问我一个问题:如何通过js脚本复制网页上的一个表格?看起来似乎比较有难度,不过还是搞定了,顺便把解决这个问题的过程记录下来,希望能对写脚本的兄弟们有所帮助. 以前没有写过这种脚本,不过想起来前不久刚看到一个脚本可以实现全选HTML编辑器的内容,于是想到一个方案:使用脚本将该表格插入HTML编辑器中,然后全选HTML编辑器内容,执行HTML编辑器的复制命令,即可实现复制表格功能,很快搞定: 测试 测试表格 测试表格 测试表格 测试表格 文字 "); // 初始化编辑器 editor.doc

  • Python将多个excel表格合并为一个表格

    生活中经常会碰到多个excel表格汇总成一个表格的情况,比如你发放了一份表格让班级所有同学填写,而你负责将大家的结果合并成一个.诸如此类的问题有很多.除了人工将所有表格的内容一个一个复制到汇总表格里,那么如何用Python自动实现这些工作呢~ 我不知道有没有其他更方便的合并方法,先用Python实现这个功能,自己用就很方便了. 比如,在文件夹下有如下7个表格(想象一下有100个或更多的表格需要合并) 作为样例,每个表格的内容均为 运行程序,将7个表格合并成了test.xls 打开test.xls

  • vue+element-ui+ajax实现一个表格的实例

    实例如下: <!DOCTYPE html> <html> <head> <script src="js/jquery-3.2.1.js"></script> <script src="vue.js"></script> <!-- 引入样式 --> <link rel="stylesheet" href="https://unpkg.co

  • 基于Element封装一个表格组件tableList的使用方法

    我们项目中使用的表格一般都比较类似,如果不进行封装的话,那么每个页面都可能有一些类似的代码.不仅浪费时间,而且由于开发人员不同的开发习惯.后期维护人员需要花费一点时间去看每个人的代码.所以我直接将表格做一个二次封装,只要一个人去维护这份代码即可.下面是我封装的内容 内容: 1.支持直接传入后台请求地址渲染列表,且参数修改之后自动刷新 2.支持自定义每一列的显示 3.支持根据内容自动撑开列宽 4.支持动态筛选表头 5.支持分页 6.防抖 7.列权限 ... 更多请自行尝试 以下是tableList

  • Springboot实现给前端返回一个tree结构方法

    目录 1:首先我们看一下数据库的表: 这里的pid就是代表他的父节点id,如果没有父节点,那么pid就是0,上面的表就可以看作是一个tree结构,那么我们怎样去将这个tree结构返回给前端呢? 2:首先写好数据库对应的实体类和Dto层: package com.wyr.modules.example.domain; import com.baomidou.mybatisplus.annotation.FieldFill; import com.baomidou.mybatisplus.annot

  • 解决LayUI数据表格复选框不居中显示的问题

    解决LayUI数据表格复选框不居中显示的问题 最后在样式文件中增加如下代码: .layui-table-cell .layui-form-checkbox[lay-skin="primary"]{ top: 50%; transform: translateY(-50%); } 完美解决: 以上这篇解决LayUI数据表格复选框不居中显示的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们.

  • 关于Go 空结构体的 3 种使用场景

    目录 1.为什么使用 2.空结构体的特殊性 3.使用场景 3.1 实现方法接收者 3.2 实现集合类型 3.3 实现空通道 前言: 在 Go 语言中,有一个比较特殊的类型,经常会有刚接触 Go 的小伙伴问到,又或是不理解. 他就是 Go 里的空结构体(struct)的使用,常常会有看到有人使用: ch := make(chan struct{}) 还清一色的使用结构体,也不用其他类型.高度常见,也就不是一个偶发现象了,肯定是背后必然有什么原因. 1.为什么使用 说白了,就是希望节省空间.但,新问

随机推荐