MYSQL练习篇31-45题

31、查询课程编号为 01 且课程成绩在 80 分以其上的学生的学号和姓名

方式一、
SELECT t1.Sname,t1.SId,t2.score
from student as t1
INNER JOIN sc as t2
on t1.SId=t2.SId
where t2.CId='01' and t2.score>=80;

方式二、
SELECT Sname,SId
from student
WHERE SId in(
SELECT SId
from sc 
where CId='01' and score>=80)

32、求每门课程的学生人数

SELECT cid,count(sid)
FROM sc 
GROUP BY CId

33、成绩不重复,查询选修「张三」老师所授课程的学生中,成绩最高的学生信息及其成绩
知识点:limit的用法

select student.*,sc.score
from student ,course ,teacher ,sc
where course.CId=sc.CId
and course.TId=teacher.TId
and teacher.Tname='张三'
and student.SId =sc.SId
ORDER BY sc.score DESC
limit 0,1

书写要注意:teacher.Tname开始写成了teacher.Tid
SELECT student.*,sc.score
from student 
INNER JOIN sc on student.SId=sc.SId
INNER JOIN course on course.CId=sc.CId
INNER JOIN teacher on teacher.TId=course.TId
where teacher.Tname = "张三"
LIMIT 1

34、成绩有重复的情况下,查询选修「张三」老师所授课程的学生中,成绩最高的学生信息及其成绩

select student.*, sc.score, sc.cid from student, teacher, course,sc 
where teacher.tid = course.tid
and sc.sid = student.sid
and sc.cid = course.cid
and teacher.tname = "张三"
and sc.score = (
    select Max(sc.score) 
    from sc,student, teacher, course
    where teacher.tid = course.tid
    and sc.sid = student.sid
    and sc.cid = course.cid
    and teacher.tname = "张三"
);

35、查询不同课程成绩相同的学生的学生编号、课程编号、学生成绩
知识点: exists?,同23题一样类型

select *
from sc as t1
where exists(
select * from sc as t2 where t1.SId=t2.SId and t1.CId!=t2.CId and t1.score =t2.score )

36、查询每门功成绩最好的前两名
存在疑问??

select *
from sc as t1
where (select count(*) from sc as t2 where t1.CId=t2.CId and t2.score >t1.score)<2
ORDER BY t1.CId

37、统计每门课程的学生选修人数(超过 5 人的课程才统计)
思考:假如其中一张关联表有分组过滤等限制条件怎么使用关联语句

select sc.CId as 课程编号,count(*) as 选修人数
from sc 
GROUP BY sc.CId
HAVING count(*)>5
可以再完善把课程表关联进来

38、检索至少选修两门课程的学生学号

SELECT SId
from sc
GROUP BY SId
HAVING count(*)>2

39、查询选修了全部课程的学生信息

SELECT *
FROM student
WHERE SId in(
SELECT SId from sc
GROUP BY SId HAVING count(*)=(select DISTINCT count(*) from course ))

答案:select student.*
from sc ,student 
where sc.SId=student.SId
GROUP BY sc.SId
HAVING count(*) = (select DISTINCT count(*) from course )

40、查询各学生的年龄,只按年份来算
知识点:时间函数,年等的运算
MYSQL中 datediff、timestampdiff函数的使用

SELECT SId,Sname,Ssex,year(now())-YEAR(Sage) as "年龄"
from student

答案:timestampdiff函数
select SId,Sname,TIMESTAMPDIFF(YEAR,Sage,now()) 年龄  from student;

41、按照出生日期来算,当前月日 < 出生年月的月日则,年龄减一
知识点:DATE_FORMAT() 函数
MySQL DATE_FORMAT() 函数

select SId,Sname,(DATE_FORMAT(NOW(),'%Y')-DATE_FORMAT(Sage,'%Y') 
-(case when DATE_FORMAT(NOW(),'%m%d')>DATE_FORMAT(Sage,'%m%d') then 0 else 1 end)) 年龄 
from student;

42、查询本周过生日的学生

select *
from student 
where YEARWEEK(student.Sage)=YEARWEEK(CURDATE())

43、查询下周过生日的学生

select *
from student 
where YEARWEEK(student.Sage)=CONCAT(YEAR(CURDATE()),week(CURDATE())+1)

44、查询本月过生日的学生

select *
from student 
where EXTRACT(YEAR_MONTH FROM student.Sage)=EXTRACT(YEAR_MONTH FROM CURDATE())

45、查询下月过生日的学生

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

推荐阅读更多精彩内容

  • 我使用的Mysql版本是5.7.19。答案可能会因版本会有少许出入。如果答案有问题欢迎在评论区指出并给出你的答案。...
    大石兄阅读 16,281评论 8 21
  • 数据表介绍 --1.学生表 Student(SId, Sname, Sage, Ssex)SId 学生编号, Sn...
    ZachXu阅读 2,827评论 0 2
  • 50道SQL练习题及答案与详细分析 https://www.jianshu.com/p/cc23c19ef639[...
    将代码写成诗阅读 2,227评论 0 3
  • 网上流传较广的50道SQL训练,奋斗了不知道多久终于写完了。前18道题的难度依次递增,从19题开始的后半部分算是循...
    Kaidi_G阅读 473,434评论 312 451
  • 今天是刚认识家教老师的日子 起床:6:30 就寝:11:00 天气:晴转阴 心情:喜悦 任务清单 昨日完成的任务,...
    淡淡云曦阅读 66评论 0 0