mssql

推荐列表 站点导航

当前位置:首页 > 数据库 > mssql >

sqlserver中查询横表变竖表的sql语句简析

来源:网络整理  作者:网络  发布时间:2020-12-08 22:38
SQL 查询横表变竖表是我工作遇到过得情况,总结下来。如果有遇到这种情况的话可以参考下...
首先是三张表, CNo对应的是课程,在这里我就粘贴了。            

sqlserver中查询横表变竖表的sql语句简析

GROUP BY s.SNo,

sqlserver中查询横表变竖表的sql语句简析

sqlserver中查询横表变竖表的sql语句简析

SELECT w.SName,
s.SName
sum(case when w.CNo= 3 then w.SCgrade ELSE 0 END) AS '英语'

那么怎么办呢?
第一种写法:
SELECT s.SName,

按照常规查询

FROM



那么结果是这样的

但是这是横表 不是我想看到的结果。

复制代码 代码如下:

sum(case when s2.CNo= 3 then s2.SCgrade ELSE 0 END) AS '英语'
sum(case WHEN w.CNo =2 THEN w.SCgrade ELSE 0 END) AS '数学',
第二种写法:
INNER JOIN C c ON c.CNo = s2.CNo

复制代码 代码如下:

AS w GROUP BY w.SName
S s INNER JOIN SC s2 ON s2.SNo = s.SNo

我们要看到这样的结果:

这是我工作遇到过得情况,总结下来。如果有遇到这种情况的话可以参考下。

sum(case when s2.CNo= 1 then s2.SCgrade ELSE 0 END) AS '语文',
FROM

主表

(SELECT s.SNo,s.SName, s2.CNo, s2.SCgrade FROM s s INNER JOIN SC s2 ON s2.SNo = s.SNo WHERE s.SNo IN (SELECT c.SNo FROM sc c GROUP BY c.SNo ))

sum(case when w.CNo= 1 then w.SCgrade ELSE 0 END) AS '语文',

sum(case WHEN s2.CNo =2 THEN s2.SCgrade ELSE 0 END) AS '数学',

sqlserver中查询横表变竖表的sql语句简析

SELECT s.SName, c.CName,s2.SCgrade


FROM S s INNER JOIN SC s2 ON s2.SNo = s.SNo INNER JOIN C c ON c.CNo = s2.CNo

人名表

相关热词: SQL语句

本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供用于网络技术学习参考,学习中请遵循相关法律法规!

本文地址: https://v30.fanwenzhu.com/sql/mssql/1577.shtml

Copyright © www.juheyunku.com      关于 | 合作 | 声明 | 联系 | 更新 | 地图 | Tags

sqlserver中查询横表变竖表的sql语句简析

2020-12-08 编辑:网络

首先是三张表, CNo对应的是课程,在这里我就粘贴了。            

sqlserver中查询横表变竖表的sql语句简析

GROUP BY s.SNo,

sqlserver中查询横表变竖表的sql语句简析

sqlserver中查询横表变竖表的sql语句简析

SELECT w.SName,
s.SName
sum(case when w.CNo= 3 then w.SCgrade ELSE 0 END) AS '英语'

那么怎么办呢?
第一种写法:
SELECT s.SName,

按照常规查询

FROM



那么结果是这样的

但是这是横表 不是我想看到的结果。

复制代码 代码如下:

sum(case when s2.CNo= 3 then s2.SCgrade ELSE 0 END) AS '英语'
sum(case WHEN w.CNo =2 THEN w.SCgrade ELSE 0 END) AS '数学',
第二种写法:
INNER JOIN C c ON c.CNo = s2.CNo

复制代码 代码如下:

AS w GROUP BY w.SName
S s INNER JOIN SC s2 ON s2.SNo = s.SNo

我们要看到这样的结果:

这是我工作遇到过得情况,总结下来。如果有遇到这种情况的话可以参考下。

sum(case when s2.CNo= 1 then s2.SCgrade ELSE 0 END) AS '语文',
FROM

主表

(SELECT s.SNo,s.SName, s2.CNo, s2.SCgrade FROM s s INNER JOIN SC s2 ON s2.SNo = s.SNo WHERE s.SNo IN (SELECT c.SNo FROM sc c GROUP BY c.SNo ))

sum(case when w.CNo= 1 then w.SCgrade ELSE 0 END) AS '语文',

sum(case WHEN s2.CNo =2 THEN s2.SCgrade ELSE 0 END) AS '数学',

sqlserver中查询横表变竖表的sql语句简析

SELECT s.SName, c.CName,s2.SCgrade


FROM S s INNER JOIN SC s2 ON s2.SNo = s.SNo INNER JOIN C c ON c.CNo = s2.CNo

人名表

本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供学习参考!
本文地址为 https://v30.fanwenzhu.com/sql/mssql/1577.shtml

相关文章

风云图片

推荐阅读

返回mssql频道首页