create view available_course_view -> as -> select course.course_no,course_name,teacher_name, -> up_limit,count(*) as student_num,up_limit-count(*) available -> from choose join course on choose.course_no=course.course_no -> join teacher on teacher.teacher_no=course.teacher_no -> group by course_no -> union all -> select course.course_no,course_name,teacher_name,up_limit,0,up_limit -> from course join teacher on teacher.teacher_no=course.teacher_no -> where not exists( -> select * from choose where course.course_no=choose.course_no -> );
时间: 2024-04-04 11:31:38 浏览: 92
这是一个 SQL 查询语句,用于创建一个名为 available_course_view 的视图,该视图用于显示可选课程的相关信息。该视图包括课程编号、课程名称、教师姓名、人数上限、已选人数以及可选人数等信息。具体实现方式是通过将选课表 choose 和课程表 course 进行联接查询,再将结果与教师表 teacher 进行联接,最后使用 group by 子句进行分组,计算出每个课程的已选人数以及可选人数。同时,使用 union all 运算符将未被选择的课程也加入到视图中。
阅读全文