请问:如何用sql语句来查询有多少学生选修课呢?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了请问:如何用sql语句来查询有多少学生选修课呢?相关的知识,希望对你有一定的参考价值。

参考技术A

study(sno,cno,score)查询至少选修了两门课程的学生学号:π1(σ(1=4Λ2!=5)(study x study))。

select sno(学生的学号) from sc(学生选课表)

group by sno having count(*)>1

select a.学号,b.姓名,a.cnt as 选修门数 from 

(select 学号,count(1) as as cnt from 选课表 group by 学号 

having count(1)=(select count(1) from 课程表)) a,

学生表 b where a.学号=b.学号;

扩展资料:

设关系R和关系S具有相同的目n,且相应的属性取自同一个域,则关系R与关系S的差由属于R而不属于S的所有元组组成。其结果关系仍为n目关系。记作:

R-S=t|t∈R∧t∉S

设关系R和关系S具有相同的目n,且相应的属性取自同一个域,则关系R与关系S的交由既属于R又属于S的元组组成。其结果关系仍为n目关系。记作:

R∩S=t|t∈R∧t∈S

这里的笛卡尔积严格地讲是广义笛卡尔积(Extended Cartesian Product)。在不会出现混淆的情况下广义笛卡尔积也称为笛卡尔积。

两个分别为n目和m目的关系R和S的广义笛卡尔积是一个(n+m)列的元组的集合。元组的前n列是关系R的一个元组,后m列是关系S的一个元组。若R有k1个元组,S有k2个元组,则关系R和关系S的广义笛卡尔积有k1×k2个元组。

参考资料来源:百度百科-关系代数

以上是关于请问:如何用sql语句来查询有多少学生选修课呢?的主要内容,如果未能解决你的问题,请参考以下文章

如何用SQL语句的查询实现两个表之间的查询连接

写一个SQL语句,查询选修了5门课程的学生学号和姓名

写一个SQL语句,查询选修了5门课程的学生学号和姓名

sql server如何用print语句输出查询结果

mysql三表查询sql语句

写一条SQL语句,查询选修了所有课程的学号。