本次查询我们基于这几张表查询

***********查询练习**********

1、 查询Student表中的所有记录的Sname、Ssex和Class列。

select sname,ssex,class from student;

2、 查询教师所有的单位即不重复的Depart列。

select distinct depart from teacher;

3、 查询Student表的所有记录。

select * from student;

4、 查询Score表中成绩在60到80之间的所有记录。

Select * from score where degree between 60 and 80;

5、 查询Score表中成绩为85,86或88的记录。

Select * from score where degree in(85,86,88);

6、 查询Student表中“95031”班或性别为“女”的同学记录。

select * from student where class=”95031” or ssex=”女” ;

7、 以Class降序查询Student表的所有记录。

Select * from student order by class desc;

8、 以Cno升序、Degree降序查询Score表的所有记录。

Select * from score order by cno, degree desc;

9、 查询“95031”班的学生人数。

select count(*) from student where class = '';

10、 查询Score表中的最高分的学生学号和课程号。(子查询或者排序)

Select sno,cno,max(degree) from score group by cno;

11、 查询每门课的平均成绩。

Select cno,avg(degree) from score group by cno;

12、查询Score表中至少有5名学生选修的并以3开头的课程的平均分数。

Select cno,avg(degree) from score where (select count(sno) from score )

至少有五名同学选修的课程:

Select cno, count(sno)>=5,avg(degree) from score where cno like’ 3%’ ;

13、查询分数大于70,小于90的Sno列。

Select sno from score where degree >70 and degree<90;

14、查询所有学生的Sname、Cno和Degree列。

Select sname,cno,degree from student,score where student.sno=score.sno;

15、查询所有学生的Sno、Cname和Degree列。

Select sno,cname,degree from score,course  where course.cno=score.cno;

16、查询所有学生的Sname、Cname和Degree列。

Select sname,cname,degree from student,course,score where student.sno=score.sno and course.cno=score.cno;

17、查询“95033”班学生的平均分。

Select class,avg(degree)  from student,score where student.sno=score.sno class=’95033’;

18、查询选修“3-105”课程的成绩高于“109”号同学成绩的所有同学的记录。

Select * from student,score where student.sno=score.sno and cno=’3-105’ and degree>(select degree from score where sno=’109’ and cno=’3-105’);

19、查询score中选学多门课程的同学中分数为非最高分成绩的记录。

先取出每科成绩的最高成绩

Select cno,max(degree) from score group by cno having count(*)>1;

select score.sno,score.cno,score.degree from score

join

(Select cno,max(degree) as big from score group by cno having count(*)>1)as a

on

score.cno = a.cno and score.degree <> a.big;

20、查询成绩高于学号为“109”、课程号为“3-105”的成绩的所有记录

Select * from score where cno='3-105' and degree>(select degree from score where sno='' and cno='3-105');

21、查询和学号为108的同学同年出生的所有学生的Sno、Sname和Sbirthday列。

Select * from student where sbirthday=(select sbiryhday from student where sno=’108’);

22、查询“张旭“教师任课的学生成绩(姓名)。

先找出该老师的课程编号;

Select cno from course where tno=(select tno from teacher where tname=’张旭’);

汇总:

Select sname,degree from student,score

where student.sno=score.sno

and cno=(Select cno from course where tno=(select tno from teacher where tname='张旭'));

23、查询考计算机导论的学生成绩

先找到计算机导论的课程编号

select cno from course where cname=('计算机导论');
Select sno,degree from score where cno= (select cno from course where cname=('计算机导论'));

24、课程名(cname)称为计算机导论 的课程编号

Select cno from course where cname=(‘计算机导论’);

25、查询李诚老师教的课程名称

select tno from teacher where tname=(‘李诚’);
Select cname from course where tno=(select tno from teacher where tname=(‘李诚’));

26、教高等数学的老师是哪个系的

Select tno from course where cname=(‘高等数学’);
Select depart from teacher where tno=(Select tno from course where cname=(‘高等数学’));

27、查询选修某课程的同学人数多于5人的教师姓名。

select cno from score group by cno having count(sno)>5;
select tname from teacher where tno=(select tno from course where cno=(select cno from score group by cno having count(sno)>5));

28、查询95033班和95031班全体学生的记录。

Select * from student where class in(95033,95031);

29、查询成绩表中存在有85分以上成绩的课程Cno.

Select cno from score where degree>85;

30、查询出“计算机系“教师所教课程的成绩表。

Select * from score where cno in ();

Select cno from course where tno in();

Select tno from teacher where depart=’计算机系’;

Select * from score where cno in (Select cno from course where tno in(Select tno from teacher where depart=’计算机系’));

31、查询选修编号为“3-105”且成绩高于选修编号为“3-245”课程的同学的Cno、Sno和Degree.

根据3-105找信息并且成绩还有要求

Select min(degree) from score where cno='3-245';

Select * from score where cno=’3-105’ and degree>(Select min(degree) from score where cno='3-245');

32、查询所有教师和同学的name、sex和birthday.

select sname,ssex,sbirthday from student

union

select tname,tsex,tbirthday from teacher;

33、查询所有“女”教师和“女”同学的name、sex和birthday.

select sname,ssex,sbirthday from student where ssex='女'

union

select tname,tsex,tbirthday from teacher  where tsex='女';

34、查询所有成绩 比3-105课程平均成绩低的同学的成绩表。

Select * from score where degree <(Select avg(degree) from score where cno='3-105');

35、查询所有任课教师的Tname和Depart.

Select tname,depart from teacher;

36、查询所有未讲课的教师的Tname和Depart.

Select tname,depart from teacher where tno in (select tno from course where cno not in(select cno from score));

37、查询至少有2名男生的班号。(根据性别班级分)

Select class,count(ssex=’男’) >=2 from student;

38、查询Student表中不姓“王”的同学记录。

Select * from student where sname not like '王%';

39、查询Student表中每个学生的姓名和年龄。

Select sname, (year(now())-year(sbirthday)) as old from student;

40、查询Student表中最大和最小的Sbirthday日期值。

select max(sbirthday),min(sbirthday)    from student;

41、以班号和年龄从大到小的顺序查询Student表中的全部记录。

Select * ,(year(now())-year(sbirthday)) as old from student order by  class desc,old desc;

42、查询“男”教师及其所上的课程。

Select tno from teacher where tsex= '男';

Select cno,cname from course where tno in (Select tno from teacher where tsex= '男');

43、查询最高分同学的Sno、Cno和Degree列。

Select * from score where degree=(select max(degree) from score);

44、查询和“李军”同性别的所有同学的Sname.

Select * from student where ssex=(select ssex from student where sname= '李军');

45、查询和“李军”同性别并同班的同学Sname.

Select sname from student where class=(select class from student where sname= '李军') and ssex=(select ssex from student where sname= '李军');

46、查询所有选修“计算机导论”课程的“男”同学的成绩表。

Select cno from course where cname= '计算机导论'

Select sno from student where ssex= '男'

Select * from score where cno in (Select cno from course where cname= '计算机导论')

And sno  in (Select sno from student where ssex= '男');

MySql——查询题目练习的更多相关文章

  1. mysql练习题目试水50题,附建库sql代码

    如果你没试过水的话,那一题一题地每一题都敲一遍吧.不管它们对你看来有多么简单.  建库代码 部分题目答案在末尾,可用ctrl f  搜索题号. 作业练习——学生-选课 表结构 学生表: Student ...

  2. MySQL查询练习2

    MySQL查询练习2 导读: 本次MySQL的查询语句是本人考试题目: 所有题目都已通过: 该查询练习并没有sql文件进行检查: 如果有书写以及其他错误欢迎指出. 题目正文: 1.找出借书超过5本的借 ...

  3. mysql查询性能优化

    mysql查询过程: 客户端发送查询请求. 服务器检查查询缓存,如果命中缓存,则返回结果,否则,继续执行. 服务器进行sql解析,预处理,再由优化器生成执行计划. Mysql调用存储引擎API执行优化 ...

  4. Mysql查询——深入学习

    1.开篇 之前上一篇的随笔基本上是单表的查询,也是mysql查询的一个基本.接下来我们要看看两个表以上的查询如何得到我们想要的结果. 在学习的过程中我们一起进步,成长.有什么写的不对的还望可以指出. ...

  5. Mysql 查询练习

    Mysql 查询练习 ---创建班级表 create table class( cid int auto_increment primary key, caption ) )engine=innodb ...

  6. mysql 查询去重 distinct

    mysql 查询去重 distinct   待完善内容..

  7. MySQl查询区分大小写的解决办法

    通过查询资料发现需要设置collate(校对) . collate规则: *_bin: 表示的是binary case sensitive collation,也就是说是区分大小写的 *_cs: ca ...

  8. 【转】mysql查询结果输出到文件

    转自:http://www.cnblogs.com/emanlee/p/4233602.html mysql查询结果导出/输出/写入到文件 方法一: 直接执行命令: mysql> select ...

  9. MySQL查询缓存

    MySQL查询缓存 用于保存MySQL查询语句返回的完整结果,被命中时,MySQL会立即返回结果,省去解析.优化和执行等阶段. 如何检查缓存? MySQL保存结果于缓存中: 把SELECT语句本身做h ...

随机推荐

  1. JS跨页面或跨JS文件对变量赋值

    JS跨页面或跨JS文件对变量赋值,这是很小的一个问题. 但问题虽小,却总觉得有点不够自然,不爽. 为什么呢?访问一个页面上的变量不是什么难事,比如用parent.变量名,或者windows名.变量名, ...

  2. FFmpeg再学习 -- FFmpeg+SDL+MFC实现图形界面视频播放器

    继续看雷霄骅的 课程资料 - 基于FFmpeg+SDL的视频播放器的制作最后一篇,主要是想学一下 MFC 创建和配置. 一.创建 MFC 工程 文件->新建->项目->Visual ...

  3. mysql动态扩容调研

    MySQL动态扩容方案 目前可用方案 MySQL的复制: 一个Master数据库,多个Salve,然后利用MySQL的异步复制能力实现读写分离,这个方案目前应用比较广泛,这种技术对于以读为主的应用很有 ...

  4. Keras 自定义层

    1.对于简单的定制操作,可以通过使用layers.core.Lambda层来完成.该方法的适用情况:仅对流经该层的数据做个变换,而这个变换本身没有需要学习的参数. # 切片后再分别进行embeddin ...

  5. 关于HslCommunication组件的双模式客户端的说明,此说明适用于所有的派生类客户端,包括三菱,西门子,欧姆龙,modbustcp,机器人,simplifyNet客户端等等

    前言 本文主要是答疑文章,针对广大网友非常频繁的提问而总结的问题 nuget地址:https://www.nuget.org/packages/HslCommunication/            ...

  6. python常用模块之sys模块

    python常用模块之sys模块 1.sys.argv[]:命令行参数List,第一个元素是程序本身 # 写一个简单的python程序,代码如下: #!/usr/bin/python #coding= ...

  7. linux c++ 服务器端开发面试必看书籍

    摘自别人博客,地址:http://blog.csdn.net/qianggezhishen/article/details/45951095 打算从这开始一本一本开始看 题外话: 推荐一个 githu ...

  8. caffe学习3——layers

    1 layer是模型的本质,是计算的基本单元.Layers convolve filters, pool, take inner products, apply nonlinearities like ...

  9. Markdown 效果测试

    欢迎使用 Cmd - 在线 Markdown 编辑阅读器 \[ \int e^{-x^2 - y^2} dx = \sqrt{2 \pi} \] 我们理解您需要更便捷更高效的工具记录思想,整理笔记.知 ...

  10. python发送邮件的实例代码(支持html、图片、附件)

    转自http://www.jb51.net/article/34498.htm 第一段代码 #!/usr/bin/python# -*- coding: utf-8 -*- import emaili ...