USE teaching SELECT A.sno, sname, C.cno, cname, score FROM student A ,sc B , course C where B.cno=C.cno and A.sno=B.sno AND score>=90 该程序的功能是:
时间: 2023-07-16 10:12:11 浏览: 136
该程序的功能是查询学生的成绩信息,包括学生学号、姓名、课程编号、课程名称和分数,但是只查询分数大于等于90分的记录。查询结果来自三个表:student(学生表)、sc(成绩表)和course(课程表)。通过INNER JOIN语句连接这三个表,并使用WHERE子句过滤出分数大于等于90分的记录。最终查询结果会包括学生的姓名、课程的名称以及对应的分数信息。
相关问题
CREATE VIEW V_S_C_G AS SELECT student.sno,sname,course.cno,cname,grade FROM course INSERT JOIN sc ON course.cno=sc.cno INSERT JOIN student ON sc.cno=student.cno 报错:You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'INSERT JOIN sc ON course.cno=sc.cno INSERT JOIN student ON sc.cno=student.cno' at line 5 应该怎么改
您的 SQL 语法有误,应该将 "INSERT" 改为 "INNER",即:
```
CREATE VIEW V_S_C_G AS
SELECT student.sno, sname, course.cno, cname, grade
FROM course
INNER JOIN sc ON course.cno = sc.cno
INNER JOIN student ON sc.sno = student.sno;
```
这样就可以创建一个名为 V_S_C_G 的视图,其中包含学生信息、课程信息和成绩信息。
CREATE VIEW V_SCG AS SELECT Sno,Sname,Cname,Score,Credit from student,grade,course WHERE grade.Sno = student.Sno AND grade.Cno = course.Cno AND Cno = '0001'; 哪里错了
在这个 SQL 查询语句中,FROM 子句中的表 student、grade、course 没有使用 JOIN 操作符链接,而是使用了逗号分隔,这会导致查询结果出现笛卡尔积,即每个表中的每一行都与其他表中的每一行进行组合,从而导致查询结果出现重复数据。解决这个问题的方法是使用 JOIN 操作符来链接这些表,并在 ON 子句中指定连接条件。另外,查询中的 Cno = '0001' 应该指定表的别名,例如 course.Cno = '0001'。修改后的 SQL 查询语句如下所示:
```
CREATE VIEW V_SCG AS
SELECT Sno,Sname,Cname,Score,Credit
FROM student
JOIN grade ON student.Sno = grade.Sno
JOIN course ON grade.Cno = course.Cno
WHERE course.Cno = '0001';
```
阅读全文