41 使用jxgl数据库,查询没有被选修过的课程的课程号和课程名。 select cno,cname from Course join sc on Course.cno=sc.cno where Course.cno = Null;
时间: 2024-02-13 11:07:58 浏览: 76
这个查询语句有一些问题,正确的查询语句应该是:
```
SELECT cno, cname FROM Course
WHERE cno NOT IN (SELECT cno FROM SC);
```
这个查询语句的意思是先在 SC 表中找出所有已经被选修过的课程号,然后在 Course 表中找出所有不在这个列表中的课程,即为没有被选修过的课程,最后查询出课程号和课程名。
相关问题
使用jxgl数据库,查询学生选修课程的信息(学生学号,学生姓名,课程号,课程名) select sno,sname,cno,cname from Students, course;
这个查询语句是有问题的,因为它没有连接学生选课表,不能正确查询学生选修课程的信息。正确的查询语句应该是:
```
SELECT students.sno, students.sname, sc.cno, course.cname
FROM students, sc, course
WHERE students.sno = sc.sno AND sc.cno = course.cno;
```
这个查询语句使用了学生表、选课表和课程表三个表的信息,通过连接学生表和选课表,以及连接选课表和课程表,正确查询了学生选修课程的信息。
38使用jxgl数据库,查询选修课程最多的同学的学号和姓名。 select sno,sname from Students join SC on Students.sno=SC.sno order by sno desc limit 1,1;
根据你的要求,我可以使用以下SQL语句来查询选修课程最多的同学的学号和姓名:
```
SELECT s.sno, s.sname
FROM Students s
JOIN SC c ON s.sno = c.sno
GROUP BY s.sno, s.sname
ORDER BY COUNT(c.cno) DESC
LIMIT 1;
```
这条SQL语句将会根据选修课程的数量降序排列,并且只返回选修课程最多的同学的学号和姓名。注意,这个查询语句假设你的选修课程信息存储在名为SC的表中,学生信息存储在名为Students的表中,且学生表中的学号sno和选修表中的学号sno是匹配的。