子查询

数据库中的表沿用 上一篇博客 中使用的Employee1.

练习:

1.求所有年龄比张三小的人

select *
from Employee1
where age < (select age
from employee1
where name = '张三');

2.求年龄比平均年龄小的人

select *
from employee1
where age <(select AVG(age)
from employee1);

分组查询

group by 子句
只有跟在group by后面的列才能写到select后面

  1. 求每个部门的平均薪资

select depart,AVG(salary)
from employee1
group by depart;

2.求每个部门相同年龄的人的平均薪资

select depart,age,AVG(salary)
from employee1
group by depart,age;

3.求最大薪资大于10000的部门的平均薪资
having子句 只用来过滤分组情况
一般来说只会跟聚合函数相关的判断

select depart,AVG(salary)
from employee1
group by depart
having MAX(salary) > 10000;

4.求薪资大于等于15000的员工人数>1的部门

select depart,count()
from employee1
where salary >= 10000
group by depart
having count(
)>1;

5.求年龄小于30 的员工最大薪资大于10000的部门

select depart
from employee1
where age < 30
group by depart
having max(salary) > 10000;

6.求年龄小于30 的员工最大薪资大于10000的部门的全部员工

select *
from Employee
where depart in(select depart
from employee
where age < 30
group by depart
having max(salary) > 10000);

  • 先看最后要得到的结果是什么
    员工表中差部门 分组
  • 哪些是对表中数据本身的限制
    在员工表中对员工有限制 那么限制写在where后面
  • 哪些条件是对分组的限制
    比如所有的聚合函数有限制 写在having后面

练习:

成绩表:

  1. 查询每个部门的总薪资

select depart,sum(salary)
from employee1
group by depart;

  1. 员工数超过3人的部门的最高薪资和最低薪资

select depart,max(salary),min(salary),count()
from employee1
group by depart
having count(
) > 3;

  1. 工龄超过3年的员工中,薪资最低的所有员工信息

select *
from Employee1
where salary in (select MIN(salary)
from Employee1
where workage > 3);

  1. 工龄超过3年的员工数大于2的部门

select depart,count()
from Employee1
where workage > 3
group by depart
having count(
) >2 ;

上周的成绩表

  1. 查询90分以上的学生的课程名和成绩

select sname,cname,grade
from score
where grade > 90;

  1. 查询每个学生的成绩在90分以上的各有多少门

select sname,count(grade)
from Score
where grade > 90
group by sname
having COUNT(grade);

  1. 至少有两门课程在90分以上的学员以及90分以上的课程数

select sname,count()
from Score
where grade > 90
group by sname
having count(
) >= 2;

  1. 平均成绩比张三的平均成绩低的学员和其平均分

select sname,AVG(grade)
from Score
group by sname
having AVG(grade) < (
select AVG(grade)
from Score
where sname = '张三'
);

  1. 查询平均成绩大于90分并且语文课95分以上的学生名和平均成绩

select sname,AVG(grade)
from Score
where sname in ( select sname
from Score
where (cname = '语文' and grade >= 95))

  1. 查询每个学员的平均分和学生名

select sname,AVG(grade)
from score
group by sname
having AVG(grade);

  1. 查询每门课的最好成绩和平均分

select cname,AVG(grade),MAX(grade)
from score
group by cname
having AVG(grade);

  1. 查询数学课成绩最好的学员的所有成绩

select *
from score
where sname in (select sname
from score
where grade = (select MAX(grade)
from score
where cname = '数学')
and cname = '数学');

  1. 查询学员及其总分,按总分降序排列

select sname,sum(grade)
from score
group by sname
having sum(grade)
order by sum(grade) desc;

2019.3.25 SQL语句(进阶2)的更多相关文章

  1. 2019.3.25 SQL语句(进阶篇1)

    运算符 基本的加减乘除取余都可以在SQL中使用 新建Employee1表并添加数据 create table Employee1 (eid int primary key auto_increment ...

  2. sql语句进阶教程

    转载自:http://blog.csdn.net/u011001084/article/details/51318434 最近从图书馆借了本介绍SQL的书,打算复习一下基本语法,记录一下笔记,整理一下 ...

  3. 2019.3.22 SQL语句(基础篇)

    SQL语句 创建一个数据库: create database+数据库名; 使用数据库: use+数据库名; 查看mySQL中有哪些数据库: show databases; 删除数据库 drop dat ...

  4. 2019.3.26 SQL语句(进阶3)

    表的联查 员工表与部门表 员工表:id,姓名,年龄,部门id 部门表:部门id,部门名,部门成立时间,部门领导,部门职责.... 表和表之间的关系 一对一 一对多 多对多 创建联查 创建表 先创建被依 ...

  5. oracle高性能的SQL语句的写法

    1.当多表查询的时候,把数据量小的表放在最后面,ORACLE会把最后面的表当作基础表,因为表间连接时,最右边的表会被放到嵌套循环的最外层.最外层的循环次数越少,效率越高. 2.Oracle采用自下而上 ...

  6. JDBC进阶之PreparedStatement执行SQL语句(MySQL)

    一.什么是PreparedStatement           参阅Java API文档,我们可以知道,PreparedStatement是Statement的子接口(如图所示),表示预编译的 SQ ...

  7. 能写数据后台,需要掌握哪些进阶的sql语句?

    国庆假期花了一些时间,首次尝试并玩转 grafana,这几天继续不断优化和完善,如今看着自己的成果,相当满意.--逐步接近我想要的理想后台啦. 需求是不停歇的.今天我又给自己发掘了一些新需求,比如变量 ...

  8. MySQL学习-数据库设计以及sql的进阶语句

    1.数据库设计 关系型数据库建议在E-R模型的基础上,我们需要根据产品经理的设计策划,抽取出来模型与关系,制定出表结构,这是项目开始的第一步 在开发中有很多设计数据库的软件,常用的如power des ...

  9. SQL语句练习(进阶版)

    学生数据库中有三个基本表(关系)如下: 学生表S(Sno,Sname,Age,Sex,SD) 课程表C(Cno,Cname, Teacher) 选课表SC(Sno,Cno,Grade) 请用SQL语言 ...

随机推荐

  1. 6.python探测Web服务质量方法之pycurl模块

    才开始学习的时候有点忽略了这个模块,觉得既然Python3提供了requests库,为什么多此一举学习这个模块.后来才发现pycurl在探测Web服务器的时候的强大. pycurl是一个用c语言写的l ...

  2. 在IE11(Win10)中检查up6.2配置

      1.按F12,打开调试模式    2.打开调试程序选项卡 说明:在调试程序选项卡中可看到IE加载的脚本信息是否正确.因为IE有缓存,导致脚本有时不是最新的.    3.打开脚本,up6.js   ...

  3. do_gettimeofday使用方法

    1.简介: 在Linux中可以使用函数do_gettimeofday()函数来得到精确时间.它的精度可以达到微妙,是与C标准库中gettimeofday()用发相同的函数.在Linux内核中获得时间的 ...

  4. 策略与计费控制规则(Policy and Charging Control Rule-PCC Rule)解析及模板样例

    内容 PCC规则定义 PCC规则运行 PCC规则模板 PCC规则定义 参考文档: 3gpp ts 23.203-be0 条款6.3 策略与计费控制规则(PCC Rule),即一系列相关信息与一系列相关 ...

  5. Ubuntu下vi编辑器不听话

    编辑文件/etc/vim/vimrc.tiny,将“compatible”改成“nocompatible”非兼容模式: 并添加一句:set backspace=2 

  6. js定时更换图片

    //定时更换图片: 调用:smileChange.start(); smileChange.stop(); var smileChange = { start: function () { var t ...

  7. 为什么要引入zookeeper系统

    为什么要引入zookeeper系统?这篇文章将说明几个引入zookeeper的原因,首先,先对zookeeper做一个简单的介绍. zookeeper是hadoop下的一个子项目,它是一个针对大型分布 ...

  8. mvc - codefirst 数据迁移

    from :http://blog.csdn.net/xiaoyiyz/article/details/41485325

  9. 大数据技术之_11_HBase学习_01_HBase 简介+HBase 安装+HBase Shell 操作+HBase 数据结构+HBase 原理

    第1章 HBase 简介1.1 什么是 HBase1.2 HBase 特点1.3 HBase 架构1.3 HBase 中的角色1.3.1 HMaster1.3.2 RegionServer1.3.3 ...

  10. react中使用echarts(人物关系图)

    项目中有时会用到echarts,可能不同的框架中语法稍有变通,前几天在react项目中遇到,写此篇以作记录. 不同的charts语法跟支持不同,本篇"echarts": " ...