设计有数据表:
class_a(student_name,student_score),班级A,学生姓名,学分得分
class_b(student_name,student_score),班级B,学生姓名,学分得分
给出视图创建语句,汇总所有学生的得分。

关于#mysql#视图的问题,如何解决?
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
5条回答 默认 最新
关注
可以使用 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;
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报