设计有数据表:
class_a(student_name,student_score),班级A,学生姓名,学分得分
class_b(student_name,student_score),班级B,学生姓名,学分得分
给出视图创建语句,汇总所有学生的得分。
设计有数据表:
class_a(student_name,student_score),班级A,学生姓名,学分得分
class_b(student_name,student_score),班级B,学生姓名,学分得分
给出视图创建语句,汇总所有学生的得分。
收起
可以使用 SQL 的 UNION ALL 操作符将两个表合并为一个视图,并使用 GROUP BY 和 SUM 聚合函数计算每个学生的总得分。
视图创建语句如下:
```sql
CREATE VIEW all_scores AS
SELECT student_name, SUM(student_score) AS total_score
FROM (
SELECT student_name, student_score FROM class_a
UNION ALL
SELECT student_name, student_score FROM class_b
) AS combined_scores
GROUP BY student_name;
这个语句首先将 class_a 和 class_b 表中的学生姓名和得分合并到一个子查询中,然后对这个子查询进行分组并计算每个学生的总得分。最后将结果作为一个视图 all_scores 返回。
查询 all_scores 视图可以得到所有学生的总得分
SELECT * FROM all_scores;
报告相同问题?