24小时热门版块排行榜    

查看: 1091  |  回复: 4

huycwork

金虫 (著名写手)

[交流] 求讨论,SQL对子表的检索方法已有2人参与

老师布置下了作业,要学SQL语句,呃,里面有一些奇怪的要求,诸如:

  • 查询选修了C1课程但是没有选修C2课程的学生学号,姓名。
  • 查询选修了所有课程的学生的学号,姓名。
  • 查询至少选修了学号为S2的同学所选全部课程的学生学号和姓名。

给出的数据表有三个,第一个是学生表,姑且以S表示:
CODE:
create table S(
        sno char(4) primary key,
        sname varchar(16)
);

第二个是课程表,姑且以C表示:
CODE:
create table C(
        cno char(4) primary key,
        cname varchar(16)
);

第三个是成绩表,姑且以SC表示:
CODE:
create table SC(
        sno char(4) not null,
        cno char(4) not null,
        grade numeric(4, 1) default 0,
        primary key(sno, lno),
        foreign key(sno) references S(sno),
        foreign key(cno) references C(cno)
);

像第一个查询,选了C1而没有选C2,这都还好一些,建立两个子查询就可以了:
CODE:
select S.sno as 学号, S.sname as 姓名 from S
where S.sno in
(select SC1.sno from
(select SC.sno from SC where SC.cno = 'C1') as SC1,
(select SC.sno from SC where SC.cno <> 'C2') as SC2
where SC1.sno = SC2.sno);

第二个就有点难受了,要给出所有的课程号,但是想了很久也没想出来怎么拿两个表比较出一个学号出来,只好求助count:
CODE:
select S.sno as 学号, S.sname as 姓名
from S where S.sno in(
select SC.sno from SC group by SC.sno
having count(SC.cno) = (select COUNT(*) from C));

第三个问题的性质也差不多,要首先给出一个表,然后,又没想出来怎么比较两个表,没办法,只好计数:
CODE:
select S.sno as 学号, S.sname as 姓名 from
S, (select SC.sno from SC
where SC.sno = 'S2') as SC2 left join SC
on SC.sno=SC2.sno
where S.sno = SC.sno
group by S.sno,S.sname
having COUNT(SC.cno) =
(select COUNT(SC.cno) from SC where SC.sno = 'S2');

我实在不想再玩这种复杂到头疼的代码了,求教育!求讨论!

对于这种需要对比两个或以上数据表以得出数据的select,有什么简单而有效的方法可以实际完成这样的工作?上面给出的代码并没有平行地比较两个表得出学号,有点旁门左道的感觉呃~

附上数据库的二进制样本,SQL Server 生成,用于还原数据库的。[ Last edited by huycwork on 2011-6-9 at 22:37 ]
回复此楼
漩涡的中心有一块空地,空空的。
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

xiangling1

金虫 (正式写手)

★ ★
小木虫(金币+0.5):给个红包,谢谢回帖
jjdg(金币+1): 感谢参与 2011-06-16 01:48:24
搞金融怎么干上程序了
黄沙百战穿金甲,不破楼兰终不还!
2楼2011-06-15 19:25:01
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

huycwork

金虫 (著名写手)


dubo(金币+1): 欢迎常来程序语言版讨论 2011-06-19 19:42:50
引用回帖:
Originally posted by xiangling1 at 2011-06-15 19:25:01:
搞金融怎么干上程序了

金融的核心目的是拿钱去赚钱,先决条件是有钱。
漩涡的中心有一块空地,空空的。
3楼2011-06-15 19:51:58
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

sudo

木虫 (正式写手)

★ ★
小木虫(金币+0.5):给个红包,谢谢回帖
dubo(金币+1): 欢迎常来程序语言版讨论 2011-06-19 19:42:58
看来这里的人都不研究SQL啊,我也一窍不通~
4楼2011-06-16 11:00:47
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

huycwork

金虫 (著名写手)


dubo(金币+1): 欢迎常来程序语言版讨论 2011-06-19 19:43:17
引用回帖:
Originally posted by sudo at 2011-06-16 11:00:47:
看来这里的人都不研究SQL啊,我也一窍不通~

唉~这个版块就不晓得怎么开的~浪费学习热情
漩涡的中心有一块空地,空空的。
5楼2011-06-16 11:19:52
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 huycwork 的主题更新
普通表情 高级回复(可上传附件)
信息提示
请填处理意见