SQL Server行列转换:一题多解
5星 · 超过95%的资源 需积分: 11 174 浏览量
更新于2024-12-04
收藏 3KB TXT 举报
"这道Java面试题探讨了如何在数据库层面进行行列转换,特别是使用Oracle和SQL Server两种数据库管理系统的方法。示例展示了SQL Server 2000如何将数据从行转换为列,并提供了详细的SQL查询语句来完成这个转换。"
在数据库管理中,行列转换是一种常见的操作,特别是在数据分析和报表生成时。Java面试题中提到的这个问题是关于如何在SQL查询中实现这种转换。首先,我们来看SQL Server 2000的例子,原始数据是一个表格,包含sid(学生ID)、cid(课程ID)和mark(分数)三个字段。
原始数据示例如下:
```
sid cid mark
030611 1000 70
030611 1001 80
...
```
目标是将这些数据转换成如下格式:
```
sid 1000 1001 1002 1003 1004 ܷ ƽ ߷
030611 70 80 75 86 70 381 76 86
```
这里1000到1004表示不同的课程ID,对应的值是各科的总分,"ܷ"是所有课程的总分,"ƽ"是平均分,"߷"是最高分。
转换方法使用了SQL的CASE语句和GROUP BY子句。具体的SQL查询语句如下:
```sql
SELECT
sid,
[1000] = SUM(CASE cid WHEN '1000' THEN mark ELSE NULL END),
[1001] = SUM(CASE cid WHEN '1001' THEN mark ELSE NULL END),
[1002] = SUM(CASE cid WHEN '1002' THEN mark ELSE NULL END),
[1003] = SUM(CASE cid WHEN '1003' THEN mark ELSE NULL END),
[1004] = SUM(CASE cid WHEN '1004' THEN mark ELSE NULL END),
[ܷ] = SUM(CASE sid WHEN sid THEN mark ELSE NULL END),
[ƽ] = AVG(CASE sid WHEN sid THEN mark ELSE NULL END),
[߷] = MAX(CASE sid WHEN sid THEN mark ELSE NULL END)
FROM sc
GROUP BY sid;
```
这段SQL代码首先按sid分组,然后使用CASE语句根据cid的值将每一行的数据累加到对应的列上。如果cid与指定的值不匹配,就返回NULL,因此在SUM函数中不会计入计算。最后,计算每个sid的总分、平均分和最高分。
在Oracle数据库中,可以使用PIVOT函数来完成类似的操作,语法可能略有不同。但是,由于题目没有提供Oracle的具体实现,所以这里不做详细展开。
行列转换是数据库操作中的一个重要技巧,它能够帮助我们将数据以更直观的方式呈现,尤其在处理多维数据或生成汇总报告时非常有用。对于开发人员来说,理解和掌握这种技巧对于提升数据库查询效率和数据处理能力具有重要意义。
446 浏览量
674 浏览量
228 浏览量
902 浏览量
2361 浏览量
292 浏览量
240 浏览量
lin0207180
- 粉丝: 1
- 资源: 18
最新资源
- lingo基础教程 快速入门
- asp.net xml教程
- keil uvision3与PROTEUS7软件连接的完美教程
- MCS-51单片机温度控制系统
- Qt Designer And Kdevelop-3.0 For Beginners.pdf
- C语言嵌入式系统编程修炼之道.pdf
- JAVA2核心技术第1卷:基础知识7th.pdf
- 电路第五版,邱关源,第五版课件
- 3G基础知识讲座,3G知识入门讲座
- javascript常用100语句
- 08年程序员考试下午试题
- maple的基础教程
- 更新至08年的程序员试题
- SCO5.0.7安装说明
- Win2003下iis+php+mysql+zend架设
- 关于开发工具Ant, JBuilder, Eclipse, workshop等使用的FAQ以及资源