24小时热门版块排行榜    

查看: 1158  |  回复: 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 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 274求调剂 +5 S.H1 2026-03-18 5/250 2026-03-18 21:27 by guosr9609
[考研] 085600材料与化工调剂 324分 +8 llllkkkhh 2026-03-18 8/400 2026-03-18 21:01 by Catalysis25
[考研] 328求调剂,英语六级551,有科研经历 +3 生物工程调剂 2026-03-16 10/500 2026-03-18 20:41 by Wangjingyue
[考研] 一志愿天津大学化学工艺专业(081702)315分求调剂 +10 yangfz 2026-03-17 10/500 2026-03-18 20:14 by walc
[考研] 一志愿武理材料305分求调剂 +5 想上岸的鲤鱼 2026-03-18 6/300 2026-03-18 17:53 by 无际的草原
[考研] 286求调剂 +6 lemonzzn 2026-03-16 9/450 2026-03-18 15:31 by vgtyfty
[考研] 08工科 320总分 求调剂 +5 梨花珞晚风 2026-03-17 5/250 2026-03-18 14:49 by haxia
[考研] 材料与化工一志愿南昌大学327求调剂推荐 +8 Ncdx123456 2026-03-13 9/450 2026-03-18 14:40 by haxia
[考研] 298-一志愿中国农业大学-求调剂 +7 手机用户 2026-03-17 7/350 2026-03-18 14:34 by vgtyfty
[考研] 0703化学求调剂 总分331 +3 ZY-05 2026-03-13 3/150 2026-03-18 10:58 by macy2011
[硕博家园] 湖北工业大学 生命科学与健康学院-课题组招收2026级食品/生物方向硕士 +3 1喜春8 2026-03-17 5/250 2026-03-17 17:18 by ber川cool子
[考研] 332求调剂 +6 Zz版 2026-03-13 6/300 2026-03-17 17:03 by ruiyingmiao
[考研] 材料与化工专硕调剂 +5 heming3743 2026-03-16 5/250 2026-03-17 14:03 by 勇敢太监王公公
[考研] 283求调剂 +3 听风就是雨; 2026-03-16 3/150 2026-03-17 07:41 by 热情沙漠
[考研] 304求调剂 +4 ahbd 2026-03-14 4/200 2026-03-16 16:48 by 我的船我的海
[考研] 一志愿华中师范071000,325求调剂 +6 RuitingC 2026-03-12 6/300 2026-03-16 14:50 by 可淡不可忘
[考研] 中科大材料专硕319求调剂 +3 孟鑫材料 2026-03-13 3/150 2026-03-14 18:10 by houyaoxu
[考研] 265求调剂 +4 威化饼07 2026-03-12 4/200 2026-03-14 17:23 by userper
[考研] 290求调剂 +3 ADT 2026-03-13 3/150 2026-03-13 10:19 by peike
[考研] 321求调剂(食品/专硕) +3 xc321 2026-03-12 6/300 2026-03-13 08:45 by xc321
信息提示
请填处理意见