学好SQL查询:无他,概手熟耳。

1. 基础表:

学生表:

老师表:

课程表:

成绩表:

2. 题目:

1、查询名字中含有"华"字的学生信息

select * from 学生 where sname like '%华%'

2、查询并统计同龄学生人数

select sage,count(sid) from 学生 group by sage

3、查询每门课程的平均成绩,结果按平均成绩升序排列,平均成绩相同时,按课程号降序排列

select cid,avg(Cscore) from 成绩 group by cid order by avg(Cscore),cid desc

4、按平均成绩从高到低显示所有学生的平均成绩

select sid,avg(Cscore) from 成绩 group by sid order by avg(Cscore) desc

5、查询各科成绩最高分、最低分和平均分:以如下形式显示:课程ID,课程name,最高分,最低分,平均分

select sc.cid 课程ID, c.cname 课程名, max(sc.Cscore) 最高分,min(sc.Cscore) 最低分,avg(sc.Cscore) 平均分 from 成绩 sc left join 课程 c on sc.cid=c.cid
group by sc.cid

6、按各科平均成绩从低到高顺序排序

select cid, avg(Cscore) from 成绩 group by cid order by avg(Cscore) desc

7、查询学生的总成绩并进行排名

select sid 学号,sum(Cscore) 总分 from 成绩 group by sid order by sum(Cscore) desc

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

select sid from 成绩 group by sid having count(cid) > 1

9、查询每门课程被选修的学生数

select cid,count(cid) from 成绩 group by cid

10、查询不及格的课程,并按课程号从大到小排列

select * from 成绩 group by cid having cscore < 60 order by cid desc

11、查询出只选修了一门课程的全部学生的学号和姓名

select sid,sname from 学生 where sid in(
select sid from 成绩 group by sid having count(sid) = 1
)

12、查询课程编号为"01"且课程成绩在60分以上的学生的学号和姓名;

select sid,sname from 学生 where sid in(
select sid from 成绩 where
cid = 'c01'
and Cscore>=60
)

13、查询“01”课程比“02”课程成绩高的所有学生的学号;

select sc1.sid from 成绩 sc1, 成绩 sc2 where
sc1.sid = sc2.sid
and sc1.cid = 'c01'
and sc2.cid = 'c02'
and sc1.cscore > sc2.Cscore

14、查询平均成绩大于60分的同学的学号和平均成绩;

select sid, avg(Cscore) from 成绩 group by sid having avg(Cscore) > 60

15、查询姓“李”的老师的个数;

select count(1) from 教师 where Tname like '李%'

16、查询没学过“何倩文”老师课的同学的学号、姓名;

select sid, sname from 学生 where sid not in(
select sid from 成绩 where cid =(
select cid from 课程 where Cteacher = '何倩文'
)
)

17、查询学过编号“01”并且也学过编号“02”课程的同学的学号、姓名;

select sid, sname from 学生 where sid in(
select sc1.sid from 成绩 sc1 where sid in(
select sc2.sid from 成绩 sc2 where cid = 'c01'
)
and cid = 'c02'
)

select sid,sname from 学生 where sid in(
select sc1.sid from 成绩 sc1,成绩 sc2 where
sc1.sid=sc2.sid
and sc1.cid = 'c01'
and sc2.cid = 'c02'
)

18、查询没学过"李征辉"老师讲授的任一门课程的学生姓名

select sid,sname from 学生 where sid not in(
select distinct(sid) from 成绩 where cid in (
select cid from 课程 where Cteacher = '李征辉'
)
)

19、查询所有同学的学号、姓名、选课数、总成绩

select sc.sid, s.sname, count(sc.cid), sum(Cscore) from 成绩 sc
left join 学生 s on sc.sid = s.sid
group by sc.sid

20、查询学过“张三”老师所教的课的同学的学号、姓名;

select sid, sname from 学生 where sid in(
select distinct(sc.sid) from 成绩 sc
left join 课程 c on sc.cid=c.cid where c.Cteacher = '李征辉'
) order by sid

21、查询课程编号“01”的成绩比课程编号“02”课程低的所有同学的学号、姓名;

select sid, sname from 学生 where sid in(
select sc1.sid from 成绩 sc1, 成绩 sc2 where
sc1.sid = sc2.sid
and sc1.cid = 'c01'
and sc2.cid = 'c02'
and sc1.Cscore < sc2.Cscore
)

22、查询所有课程成绩小于60分的同学的学号、姓名;

select sid, sname from 学生 where sid not in(
select distinct(sid) from 成绩 where cscore >= 60
) and sid in(
select sid from 成绩 group by sid having count(sid) != 0
)

select sid, sname from 学生 where sid not in(
select s.sid from 学生 s
left join 成绩 sc on s.sid=sc.sid where Cscore > 60 or Cscore is null
)

select sid, sname from 学生 where sid in(
select sc.sid from 成绩 sc group by sid having max(sc.Cscore)<60
)

23、查询没有学全所有课的同学的学号、姓名;

select s.sid, s.sname from 学生 s
left join 成绩 sc on s.sid=sc.sid
group by s.sid having count(s.sid) != (
select count(1) from 课程
)

24、查询至少有一门课与学号为“01”的同学所学相同的同学的学号和姓名;

select sid, sname from 学生 where sid in(
select distinct(sid) from 成绩 where cid in (
select cid from 成绩 where sid = 's01'
) and sid != 's01'
)

select distinct(s.sid),sname from 学生 s
left join 成绩 sc on s.sid = sc.sid where sc.cid in(
select cid from 成绩 where sid = 's01'
)and s.sid != 's01'

25、查询和"01"号的同学学习的课程完全相同的其他同学的学号和姓名

select s.sid from 学生 s left join 成绩 sc on s.sid = sc.sid where sc.cid in(
select cid from 成绩 where sid = 's01'
) group by s.sid
having count(s.sid) =
(select count(cid) from 成绩 where sid='s01')
and s.sid != 's01'

26、把“成绩”表中“高磊”老师教的课的成绩都更改为此课程的平均成绩;

update 成绩 set Cscore = (
select avg(sc.Cscore) from 课程 c
left join 成绩 sc on c.cid = sc.cid where Cteacher = '高磊'
) where cid in (
select cid from 课程 where Cteacher = '高磊'
)

27、查询两门及其以上不及格课程的同学的学号,姓名及其平均成绩

select s.sid, s.sname, avg(sc.Cscore) from 学生 s
left join 成绩 sc on s.sid = sc.sid where s.sid in(
select sid from 成绩 sc where Cscore < 60 group by sid having count(sid) > 2
)

28、检索"01"课程分数小于60,按分数降序排列的学生信息

select * from 学生 s left join 成绩 sc on s.sid=sc.sid where
sc.Cscore < 60
and sc.cid = 'c01'
order by sc.Cscore desc

29、查询不同老师所教不同课程平均分从高到低显示

select c.Cteacher,c.Cname, avg(sc.Cscore) from 成绩 sc
left join 课程 c on sc.cid=c.cid
group by sc.cid
order by avg(sc.Cscore) desc

30、查询选修“李征辉”老师所授课程的学生中,成绩最高的学生姓名及其成绩

select s.sname, max(sc.Cscore) from 学生 s
left join 成绩 sc on s.sid=sc.sid where sc.cid in (
select cid from 课程 where Cteacher = '李征辉'
)

SQL查询语法30例的更多相关文章

  1. MySQL进阶8 分页查询(limit) - 【SQL查询语法执行顺序及大致结构】- 子查询的3个经典案例

    #进阶8 分页查询 /* 应用场景: 当要显示的数据,一页显示不全,需要分页提交sql请求 语法: select 查询列表 #7 from 表1 #执行顺序:#1 [join type join 表2 ...

  2. sql 查询最近30分钟或者自定义时间数据

    ) FROM dual; 30分钟或者自定义

  3. ThinkPHP 数据库操作(三) : 查询方法、查询语法、链式操作

    查询方法 条件查询方法 where 方法 可以使用 where 方法进行 AND 条件查询: Db::table('think_user') ->where('name','like','%th ...

  4. Mysql常用30种SQL查询语句优化方法

    出处:http://www.antscode.com/article/12deee70111da0c4.html 1.应尽量避免在 where 子句中使用!=或<>操作符,否则将引擎放弃使 ...

  5. MySQL 常用30种SQL查询语句优化方法

    1.应尽量避免在 where 子句中使用!=或<>操作符,否则将引擎放弃使用索引而进行全表扫描. 2.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉 ...

  6. 提高SQL查询效率的30种方法

    转载:提高SQL查询效率的30种方法 内容摘录如下: 1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. 2.应尽量避免在 where 子句中 ...

  7. SQL查询今天、昨天、7天内、30天【转】

    SQL查询今天.昨天.7天内.30天 今天的所有数据:select * from 表名 where DateDiff(dd,datetime类型字段,getdate())=0 昨天的所有数据:sele ...

  8. MySQL 基本语法(1.表字段操作,2表记录管理 3.运算符管理4.SQL查询 5.约束6.索引

    .表字段的操作 .语法:alter table 表名 执行动作; .添加字段(add) .添加到末尾 alter table 表名 add 字段名 数据类型; .添加到第一列 alter table ...

  9. SQL DATEDIFF语法及时间函数 Sql 查询当天、本周、本月记录

    SQL DATEDIFF语法及时间函数 Sql 查询当天.本周.本月记录 转:http://blog.csdn.net/Json1204/article/details/7863801?locatio ...

随机推荐

  1. ELK 理论小知识

    ELK 是现阶段众多企业单位都在使用的一种日志分析系统,它能够方便的为我们收集你想要的日志并且展示出来 ELK是Elasticsearch.Logstash.Kibana的简称,这三者都是开源软件,通 ...

  2. 清晰架构(Clean Architecture)的Go微服务: 程序结构

    我使用Go和gRPC创建了一个微服务,并试图找出最佳的程序结构,它可以用作我未来程序的模板. 我有Java背景,并发现自己在Java和Go之间挣扎,它们之间的编程理念完全不同.我写了一系列关于在项目工 ...

  3. 服务器上无法调用Office组件的解决方法(HRESULT:0X800A03EC异常)

    HRESULT:0X800A03EC的异常,经过多番查找,终于找到了解决方法,在 Windows 2008 中, 如果以 SYSTEM 用户跑, 系统会去寻找 SYSTEM 这个用户的 Profile ...

  4. 《Java基础知识》Java断言

    断言:也就是所谓的assertion,是jdk1.4后加入的新功能. 它主要使用在代码开发和测试时期,用于对某些关键数据的判断,如果这个关键数据不是你程序所预期的数据,程序就提出警告或退出. 当软件正 ...

  5. 为什么使用HTTP2?

    最近我们公司的官网由原来的http1.1已升级到http2,而我们前端开发对http2还是一片懵懂,更不知道为何换成了这个,故此补充了下http2的相关知识. http1.1相比于http1.0有哪些 ...

  6. python中几种自动微分库

    简单介绍下python的几个自动求导工具,tangent.autograd.sympy: 在各种机器学习.深度学习框架中都包含了自动微分,微分主要有这么四种:手动微分法.数值微分法.符号微分法.自动微 ...

  7. CMU-14445 数据库原理 汇总

    LAB1:Extendible Hash Table, LRU, BUFFER POOL MANAGER LAB2:实现一个支持并发操作的B+树 LAB3:事务隔离,two-phase locking ...

  8. BIM工程信息管理系统搭建-系统功能需求

    BIM工程信息管理系统功能需求 该系统是真实存在项目,项目于2013年开始研发到2014年初完成,按照当时技术能力和国内BIM现状,现在BIM技术已比之前好多了,不管是建模.展示等.均提高了不少,本博 ...

  9. phper使用MySQL 针对千万级的大表要怎么优化?

    有需要学习交流的友人请加入交流群的咱们一起,群内都是1-7年的开发者,希望可以一起交流,探讨PHP,swoole这块的技术 或者有其他问题 也可以问,获取swoole或者php进阶相关资料私聊管理即可 ...

  10. DG重启之后主备数据不同步

    问题描述:本来配置好的DG第二天重启之后,发现主备库数据不能同步,在主库上执行日志切换以及创建表操作都传不到备库上,造成这种错误的原因是主库实例断掉后造成备库日志与主库无法实时接收 主库:orcl  ...