Jarvan同学的例题分析及个人理解

1、查询" 01 "课程比" 02 "课程成绩高的学生的信息及课程分数
思路:先查出01课程所有学生分数作为t1,再查出02课程所有学生分数作为t2,
将两表进行联结,条件是:学生sid相同,01分数比02分数高。
如下:
(select sc.*
from sc
where sc.cid='01') as t1

(select sc.*
from sc
where sc.cid='02') as t2

select sc.*
from t1
join t2
on t1.sid=t2.sid and t1.score>t2.score

将t1,t2 替换代码如下
select t1.,t2.cid,t2.score
from (select sc.

from sc
where sc.cid='01') as t1
join (select sc.*
from sc
where sc.cid='02') as t2
on t1.sid=t2.sid and t1.score>t2.score #可按具体要求选择要显示的内容,join的写法更清晰,可读性较强

标准答案(此为sql92写法,个人认为可读性不如sql99即join写法,看个人喜好,只是做下对比)
select *
from (select SId ,score from sc where sc.CId='01')as t1 ,
(select SId ,score from sc where sc.CId='02') as t2
where t1.SId=t2.SId
and t1.score>t2.score

2、查询平均成绩大于等于 60 分的同学的学生编号和学生姓名和平均成绩
思路:对学生编号分组,找出每个学生的sid及平均成绩,再用having进行大于60分的筛选,最后进行表关联
select sc.sid,avg(sc.score) as avgscore
from sc
group by sc.sid
having avgscore >60 #分组,再过滤

关联 条件是sid相同,如下:

select sc.sid,s.sname,avg(sc.score) as avgscore
from sc
join student s
on sc.sid=s.sid
group by sc.sid
having avgscore >60

标准答案(个人认为还是写法问题,而且题目要求显示编号姓名及平均成绩,这个是搜的全部,不太严谨)
select student.*,t1.avgscore
from student inner JOIN(
select sc.SId ,AVG(sc.score)as avgscore
from sc
GROUP BY sc.SId
HAVING AVG(sc.score)>=60)as t1 on student.SId=t1.SId

3、查询在 SC 表存在成绩的学生信息
思路:个人理解的第一种解法:根据题目,直接根据sc.sid分组即可(也就是标准答案的去重),再和student表关联,如下:
select sc.sid,s.*
from sc
join student s
on sc.sid=s.sid
group by sc.sid

标准答案 用distinct去重,代码更简洁
select DISTINCT student.*
from student ,sc
where student.SId=sc.SId

第三种写法,也就是4.1的答案 ,exists的用法:
select *
from student
where EXISTS(select * from sc where student.SId=sc.SId)

7、查询没有学全所有课程的同学的信息
个人思路:用count函数先找出一共有多少课,再对sc表sid进行分组,再次用count函数找出等于课程数即学全同学的sid,
用not in 函数,筛选除sid以外的其他同学的信息
1、
select count()
from course #是3
2、
select sc.sid
from sc
group by sid
having count(sc.cid)=3 学完3门的同学的编号
3、筛选 用 not in
select s.

from student s
where s.sid not in (select sc.sid
from sc
group by sid
having count(sc.cid)=3)
4、最终答案 记得替换 3
select s.*
from student s
where s.sid not in (select sc.sid
from sc
group by sid
having count(sc.cid)=(select count(*)
from course))

标准答案解法1
select student.*
from sc ,student
where sc.SId=student.SId
GROUP BY sc.SId
Having count()<(select count() from course)
但这种解法得出来的结果不包括什么课都没选的同学

标准答案解法2 (个人感觉比较难读懂)
select DISTINCT student.*
from
(select student.SId,course.CId
from student,course ) as t1 LEFT JOIN (SELECT sc.SId,sc.CId from sc)as t2 on t1.SId=t2.SId and t1.CId=t2.CId,student
where t2.SId is null
and t1.SId=student.SId

8.查询至少有一门课与学号为" 01 "的同学所学相同的同学的信息
思路:先选出01同学所学科目的编号,再用‘in’来选出与01至少相同一门的学生编号(个人认为要排除01),最后做表关联。
select sc.cid
from sc
where sc.sid='01' #选出01同学的课程编号

select distinct sc.sid,s.sname #这里记得去重,筛选的结果一定是有重复的
from sc
join student s
on sc.sid=s.sid
where sc.sid <>'01' and sc.cid in ( select sc.cid
from sc
where sc.sid='01') #排除01同学,在01同学的课程里面选调用上面写的代码

标准答案:(个人认为不严谨,会选出01同学)
select DISTINCT student.*
from sc ,student
where sc.CId in (select CId from sc where sc.SId='01')
and sc.SId=student.SId

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,684评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,143评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,214评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,788评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,796评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,665评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,027评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,679评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,346评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,664评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,766评论 1 331
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,412评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,015评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,974评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,073评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,501评论 2 343

推荐阅读更多精彩内容

  • 希望对大家面试有帮助,很经典的几道题,大家有兴趣的话,欢迎大家加群讨论,QQ群号:295383988 问题及描述:...
    hc爱编程阅读 1,876评论 0 12
  • Student(Sid,Sname,Sage,Ssex) 学生表Course(Cid,Cname,Tid) 课程表...
    小炉炉阅读 1,438评论 0 0
  • 50个常用的sql语句Student(S#,Sname,Sage,Ssex) 学生表Course(C#,Cname...
    哈哈海阅读 1,224评论 0 7
  • 说明:以下五十个语句都按照测试数据进行过测试,最好每次只单独运行一个语句。 问题及描述: --1.学生表 Stud...
    lijun_m阅读 1,288评论 0 1
  • Student(S#,Sname,Sage,Ssex) 学生表 Course(C#,Cname,T#) 课程表 S...
    望l阅读 309评论 0 0