24小时热门版块排行榜    

Znn3bq.jpeg
北京石油化工学院2026年研究生招生接收调剂公告
查看: 1180  |  回复: 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的回帖

sudo

木虫 (正式写手)

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

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的回帖

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的回帖
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 285求调剂 +18 AZMK 2026-04-02 19/950 2026-04-08 10:33 by xingguangj
[考研] 312求调剂 +4 Say Never 2026-04-04 4/200 2026-04-08 08:41 by barlinike
[考研] 求调剂 +15 熊二想上岸 2026-04-06 15/750 2026-04-08 04:53 by 无际的草原
[考研] 考研调剂 +8 冰冰,,, 2026-04-07 8/400 2026-04-07 22:49 by JourneyLucky
[考研] 338求调剂 +5 小猪红色 678 2026-04-06 6/300 2026-04-07 21:18 by 乔哒哒哒
[考研] 化工调剂303分,过四级 +34 栖梧待风 2026-04-02 34/1700 2026-04-07 12:30 by 1018329917
[论文投稿] Decision: Revise for Editor还会送审吗 100+3 CccccccccFD 2026-04-04 5/250 2026-04-07 10:58 by 北京莱茵润色
[考研] 085600,321分求调剂 +14 大馋小子 2026-04-04 15/750 2026-04-06 22:58 by qlm5820
[考研] 求助 +3 卡卡东88 2026-04-06 4/200 2026-04-06 15:28 by going home
[考研] 346分的生物与医药08600求调剂 +6 常雨阳上岸 2026-04-05 7/350 2026-04-06 12:36 by lys0704
[考研] 0855求调剂材料 +11 红桃灼灼 2026-04-04 12/600 2026-04-06 10:26 by 蓝云思雨
[考研] 296求调剂 +3 汪!?! 2026-04-05 4/200 2026-04-05 20:13 by 啵啵啵0119
[考研] 一志愿上海海洋大学083200食品学硕,求调剂,接受其他专业083200 +4 what张 2026-04-04 5/250 2026-04-05 14:07 by chw1980_0
[考研] 26调剂 086003 +6 失活的细胞 2026-04-04 6/300 2026-04-04 09:50 by zhangdingwa
[考研] 求调剂,一志愿南京航空航天大学 ,080500材料科学与工程学硕 +10 @taotao 2026-04-03 10/500 2026-04-04 09:01 by T可可西里T
[考研] 283分材料与化工求调剂 +29 罗KAKA 2026-04-02 29/1450 2026-04-03 23:56 by userper
[考研] 数二英二348求调剂 +4 hxdzj1 2026-04-03 5/250 2026-04-03 21:25 by zhq0425
[考研] 一志愿南昌大学324求调剂 +13 hanamiko 2026-04-01 13/650 2026-04-03 18:30 by ls刘帅
[考研] 260求调剂 +6 朱芷琳 2026-04-02 6/300 2026-04-02 20:27 by 6781022
[考研] 298求B区调剂 +4 zzz,,r 2026-04-02 5/250 2026-04-02 12:17 by 土木硕士招生
信息提示
请填处理意见