SQL Server行列转换:一题多解

5星 · 超过95%的资源 需积分: 11 27 下载量 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的具体实现,所以这里不做详细展开。 行列转换是数据库操作中的一个重要技巧,它能够帮助我们将数据以更直观的方式呈现,尤其在处理多维数据或生成汇总报告时非常有用。对于开发人员来说,理解和掌握这种技巧对于提升数据库查询效率和数据处理能力具有重要意义。