24小时热门版块排行榜    

Znn3bq.jpeg
查看: 1185  |  回复: 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 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 297求调剂 +26 GENJIOW 2026-04-07 29/1450 2026-04-09 21:00 by 286640313
[论文投稿] 求助文献原文 10+3 18500821399 2026-04-08 3/150 2026-04-09 16:56 by 北京莱茵润色
[考研] 材料295 +15 小英11 2026-04-03 16/800 2026-04-09 15:44 by only周
[硕博家园] 有没有学校材料专业收跨调(一志愿085410) +5 momo(上岸版) 2026-04-06 8/400 2026-04-09 15:07 by only周
[考研] 一志愿哈工大,初试329,求环境科学与工程调剂! +11 余未辛 2026-04-06 11/550 2026-04-08 15:21 by screening
[考研] 化工学硕 285求调剂 +26 Wisjxn 2026-04-07 26/1300 2026-04-08 14:42 by screening
[考研] 281求调剂 +10 椰子蘑菇 2026-04-06 10/500 2026-04-08 11:43 by zzucheup
[考研] 277求调剂 +4 考研调剂lxh 2026-04-06 6/300 2026-04-08 10:40 by 逆水乘风
[考研] 323求调剂 +3 林zlu 2026-04-07 4/200 2026-04-07 23:21 by lbsjt
[考研] 328求调剂 +4 ghhh88888 2026-04-06 5/250 2026-04-07 14:45 by ghhh88888
[考研] 调剂 +4 mcbbc 2026-04-06 5/250 2026-04-07 12:33 by upczlm1989
[考研] 307求调剂 +3 所念及所望 2026-04-06 3/150 2026-04-06 17:30 by 土木硕士招生
[考研] 求调剂 +5 wos666 2026-04-03 5/250 2026-04-06 10:13 by 蓝云思雨
[考研] 材料专硕283求调剂 +17 试试看呗 2026-04-04 18/900 2026-04-06 09:24 by 286640313
[考研] 322求调剂 +3 嗯哼哼恒 2026-04-05 3/150 2026-04-05 19:52 by nepu_uu
[考研] 一志愿9材料学硕297已过六级求调剂推荐 +11 adaie 2026-04-04 12/600 2026-04-05 19:04 by 蓝云思雨
[考研] 085500机械专硕初试288求调剂 +3 GZJguo666- 2026-04-05 3/150 2026-04-05 18:06 by jkddd
[考研] 考研生物学考A区211,初试322,科目生化和生物综合,求调剂 +6 。。。54 2026-04-03 6/300 2026-04-05 14:54 by JOKER0401
[考研] 22408求调剂 354分 可跨专业 +3 hannnnnnn 2026-04-04 3/150 2026-04-04 14:35 by 土木硕士招生
[考研] 338求调剂 +4 zzz,,r 2026-04-03 4/200 2026-04-03 16:39 by lijunpoly
信息提示
请填处理意见