2019.3.25 SQL语句(进阶2)
子查询
数据库中的表沿用 上一篇博客 中使用的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后面
- 求每个部门的平均薪资
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后面
练习:
成绩表:

- 查询每个部门的总薪资
select depart,sum(salary)
from employee1
group by depart;

- 员工数超过3人的部门的最高薪资和最低薪资
select depart,max(salary),min(salary),count()
from employee1
group by depart
having count() > 3;

- 工龄超过3年的员工中,薪资最低的所有员工信息
select *
from Employee1
where salary in (select MIN(salary)
from Employee1
where workage > 3);

- 工龄超过3年的员工数大于2的部门
select depart,count()
from Employee1
where workage > 3
group by depart
having count() >2 ;

上周的成绩表
- 查询90分以上的学生的课程名和成绩
select sname,cname,grade
from score
where grade > 90;

- 查询每个学生的成绩在90分以上的各有多少门
select sname,count(grade)
from Score
where grade > 90
group by sname
having COUNT(grade);

- 至少有两门课程在90分以上的学员以及90分以上的课程数
select sname,count()
from Score
where grade > 90
group by sname
having count() >= 2;

- 平均成绩比张三的平均成绩低的学员和其平均分
select sname,AVG(grade)
from Score
group by sname
having AVG(grade) < (
select AVG(grade)
from Score
where sname = '张三'
);

- 查询平均成绩大于90分并且语文课95分以上的学生名和平均成绩
select sname,AVG(grade)
from Score
where sname in ( select sname
from Score
where (cname = '语文' and grade >= 95))

- 查询每个学员的平均分和学生名
select sname,AVG(grade)
from score
group by sname
having AVG(grade);

- 查询每门课的最好成绩和平均分
select cname,AVG(grade),MAX(grade)
from score
group by cname
having AVG(grade);

- 查询数学课成绩最好的学员的所有成绩
select *
from score
where sname in (select sname
from score
where grade = (select MAX(grade)
from score
where cname = '数学')
and cname = '数学');

- 查询学员及其总分,按总分降序排列
select sname,sum(grade)
from score
group by sname
having sum(grade)
order by sum(grade) desc;

2019.3.25 SQL语句(进阶2)的更多相关文章
- 2019.3.25 SQL语句(进阶篇1)
运算符 基本的加减乘除取余都可以在SQL中使用 新建Employee1表并添加数据 create table Employee1 (eid int primary key auto_increment ...
- sql语句进阶教程
转载自:http://blog.csdn.net/u011001084/article/details/51318434 最近从图书馆借了本介绍SQL的书,打算复习一下基本语法,记录一下笔记,整理一下 ...
- 2019.3.22 SQL语句(基础篇)
SQL语句 创建一个数据库: create database+数据库名; 使用数据库: use+数据库名; 查看mySQL中有哪些数据库: show databases; 删除数据库 drop dat ...
- 2019.3.26 SQL语句(进阶3)
表的联查 员工表与部门表 员工表:id,姓名,年龄,部门id 部门表:部门id,部门名,部门成立时间,部门领导,部门职责.... 表和表之间的关系 一对一 一对多 多对多 创建联查 创建表 先创建被依 ...
- oracle高性能的SQL语句的写法
1.当多表查询的时候,把数据量小的表放在最后面,ORACLE会把最后面的表当作基础表,因为表间连接时,最右边的表会被放到嵌套循环的最外层.最外层的循环次数越少,效率越高. 2.Oracle采用自下而上 ...
- JDBC进阶之PreparedStatement执行SQL语句(MySQL)
一.什么是PreparedStatement 参阅Java API文档,我们可以知道,PreparedStatement是Statement的子接口(如图所示),表示预编译的 SQ ...
- 能写数据后台,需要掌握哪些进阶的sql语句?
国庆假期花了一些时间,首次尝试并玩转 grafana,这几天继续不断优化和完善,如今看着自己的成果,相当满意.--逐步接近我想要的理想后台啦. 需求是不停歇的.今天我又给自己发掘了一些新需求,比如变量 ...
- MySQL学习-数据库设计以及sql的进阶语句
1.数据库设计 关系型数据库建议在E-R模型的基础上,我们需要根据产品经理的设计策划,抽取出来模型与关系,制定出表结构,这是项目开始的第一步 在开发中有很多设计数据库的软件,常用的如power des ...
- SQL语句练习(进阶版)
学生数据库中有三个基本表(关系)如下: 学生表S(Sno,Sname,Age,Sex,SD) 课程表C(Cno,Cname, Teacher) 选课表SC(Sno,Cno,Grade) 请用SQL语言 ...
随机推荐
- Part4_lesson3---U-Boot工作流程分析
1.程序入口 我们从什么地方去找入口呢,首先是打开顶层目录的makefile文件,在这个文件里面,每一个uboot支持的开发板都有一个配置选项,比如说,搜索smdk2440,结果如下 我们主要关注上图 ...
- 转:Linux awk 命令 说明
一. AWK 说明 awk是一种编程语言,用于在linux/unix下对文本和数据进行处理.数据可以来自标准输入.一个或多个文件,或其它命令的输出.它支持用户自定义函数和动态正则表达式等先进功能,是 ...
- 现代C++学习笔记之一入门篇:智能指针(C++ 11)
原始指针:通过new建立的*指针 智能指针:通过智能指针关键字(unique_ptr, shared_ptr ,weak_ptr)建立的指针 在现代 C++ 编程中,标准库包含智能指针,该指针用于确保 ...
- (转)Web API 入门指南 - 闲话安全
原文地址:http://www.cnblogs.com/developersupport/p/WebAPI-Security.html Web API入门指南有些朋友回复问了些安全方面的问题,安全方面 ...
- Sublime for MacOS 使用技巧
1.创建软链接,使用命令直接打开sublime编辑器 ln -s "/Applications/Sublime Text.app/Contents/SharedSupport/bin/sub ...
- MongoDB整理笔记の进程控制
查看活动进程 > db.currentOp(); > // 等同于: db.$cmd.sys.inprog.findOne() { inprog: [ { "opid" ...
- Boosting and Its Application in LTR
1 Boosting概述 2 Classification and Regression Tree 3 AdaBoost 3.1 算法框架 3.2 原理:Additive Modeling 4 Gra ...
- React + Python 七月小说网 启程(一)
一.为啥要做这个网站 很久没有写技术相关的博客了,最近几个月忙飞,各种工作,技术根本学不完,很难受. 趁着春节期间,终于有空闲时间做自己爱做的事情了,美滋滋. 热爱技术,热爱小说,于是诞生了个这么玩意 ...
- 严选 Android 路由框架优化(下篇)
3 router 框架优化 3.1 apt 生成代码量过大问题优化 思考框架本身,其实可以发现仅有 router 映射表是需要根据注解编译生成的,其他的全部代码都是固定代码,完全可以 sdk 中直接编 ...
- shipyard
https://www.ivankrizsan.se/2016/07/10/managing-containers-shipyard/ kubernetes中文社区:https://www.kuber ...