SQL Server行列转换:一题多解
5星 · 超过95%的资源 需积分: 11 80 浏览量
更新于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的具体实现,所以这里不做详细展开。
行列转换是数据库操作中的一个重要技巧,它能够帮助我们将数据以更直观的方式呈现,尤其在处理多维数据或生成汇总报告时非常有用。对于开发人员来说,理解和掌握这种技巧对于提升数据库查询效率和数据处理能力具有重要意义。
143 浏览量
2021-09-14 上传
2011-07-01 上传
2023-10-16 上传
2023-09-13 上传
2023-09-28 上传
2023-09-02 上传
2023-06-21 上传
2024-03-13 上传
lin0207180
- 粉丝: 1
- 资源: 18
最新资源
- 数据库系统原理试卷2
- Sun.Intro.Cloud.Computing.Architecture.Jun.2009.pdf
- 自考数据库系统原理试卷
- VC网络安全编程基础PDF
- QT 文件读取和写入
- QT 使用向导对话框
- QT读取系统信息--磁盘管理器
- 工程机械往复式密封进化研究
- java 最新面试题附答案
- 经典的数据挖掘相关算法
- JAVA面试题解(最新)
- The Symbian OS Architecture Sourcebook 手机操作系统的设计和演变
- linux必学的重要命令教程
- Sams - Microsoft Expression Blend Unleashed (Jun 2008)
- java面试题(各大公司的非常全)
- Struts快速学习指南