Day35

今天有事,下午没学习,只有晚上学了一个半小时,最近学习的心态不太好,要改正,明天要学够7个小时,加油OVO

Day35

/*测 试
1. 查询工资最低的员工信息: last_name, salary
2. 查询平均工资最低的部门信息
3. 查询平均工资最低的部门信息和该部门的平均工资
4. 查询平均工资最高的 job 信息
5. 查询平均工资高于公司平均工资的部门有哪些?
6. 查询出公司中所有 manager 的详细信息.
7. 各个部门中 最高工资中最低的那个部门的 最低工资是多少
8. 查询平均工资最高的部门的 manager 的详细信息: last_name, department_id, email,
salary
*/

#1. 查询工资最低的员工信息: last_name, salary
SELECT last_name,salary
FROM employees
WHERE salary=(
SELECT MIN(salary)
FROM employees
)

#2. 查询平均工资最低的部门信息

SELECT d.*
FROM departments d
WHERE d.department_id IN(
SELECT department_id
FROM employees
GROUP BY department_id
HAVING AVG(salary)=(
SELECT MIN(ag)
FROM (
SELECT AVG(salary) ag,department_id
FROM employees
GROUP BY department_id
) ag_dep));

#3. 查询平均工资最低的部门信息和该部门的平均工资


#4. 查询平均工资最高的 job 信息
SELECT j.*
FROM jobs j
WHERE job_id IN(
SELECT job_id
FROM employees
GROUP BY job_id
HAVING AVG(salary)=(
SELECT MAX(ag)
FROM (
SELECT AVG(salary) ag,job_id
FROM employees
GROUP BY job_id
) ag_emp))

#5. 查询平均工资高于公司平均工资的部门有哪些?
SELECT department_id,AVG(salary) 平均工资
FROM employees
WHERE department_id IN(
SELECT department_id
FROM employees
GROUP BY department_id
HAVING AVG(salary)>(
SELECT AVG(salary)
FROM employees
))
GROUP BY department_id

#6. 查询出公司中所有 manager 的详细信息.
SELECT last_name,manager_id
FROM employees
WHERE manager_id=(
SELECT manager_id
FROM employees
GROUP BY manager_id
)
GROUP BY manager_id


#分页查询
/*应用场景:当要显示的数据,一页显示不全,需要分页提交sql请求
语法:
select 查询列表
from 表
【join type join 表2
on 连接条件
where 筛选条件
group by 分组字段
having 分组后的筛选
order by 排序的字段】

limit 【offset,】size;

offset要显示条目的起始索引(起始索引从0开始)
size 要显示的条目个数
执行顺序
1.from子句
2.join子句
3.on子句
4.where子句
5.group by子句
6.having子句
7.select子句
8.order by 子句
9.limit子句

特点: 起始条目索引从0开始,如果不写,则是从0开始显示。
①limit语句放在查询语句的最后
②公式
要显示的页数 page,每页的条目数size

select 查询列表
from 表
limit (page-1)*size,size;

size=10
page  
1 0
2 10
3 20

*/
#案例1:查询前五条员工信息

#这两个语句一样,起始条目索引默认为0
SELECT * FROM employees LIMIT 0,5;
SELECT * FROM employees LIMIT 5;


#案例2:查询第11条——第25条
SELECT * FROM employees LIMIT 10,15;


#案例3:有奖金的员工信息,并且工资较高的前10名显示出来
SELECT
  *
FROM
  employees
WHERE commission_pct IS NOT NULL
ORDER BY salary DESC
LIMIT 10 ;

#联合查询
/*语法:
select 查询列表 from 表1 where 筛选条件
union
select 查询列表 from 表1 where 筛选条件

特点
1.多条待联合的查询语句的查询列数必须一致,查询类型、字段意义最好一致
2.union实现去重查询
 union all 实现全部查询。

*/

#DDL
/*

数据定义语言

库和表的管理

一、库的管理
创建、修改、删除
二、表的管理
创建、修改、删除

创建: create
修改: alter
删除: drop

*/

#一、库的管理
#1、库的创建
/*
语法:
create database 库名;
#提高代码的容错性,尽量用下面这个形式。
create database if not exists 库名;
*/

#2.删除数据库
#drop database 库名
#drop database if not exists 库名;

#二、表的管理
#1.表的创建 ★

/*
语法:
create table 表名(
列名 列的类型【(长度) 约束】,
列名 列的类型【(长度) 约束】,
列名 列的类型【(长度) 约束】,
...
列名 列的类型【(长度) 约束】
)
*/
CREATE TABLE book(
id INT,#编号
bName VARCHAR(20),#图书名
price DOUBLE,#价格
authorId  INT,#作者编号
publishDate DATETIME#出版日期
);

 

posted @ 2021-04-21 21:44  独眼龙  阅读(127)  评论(0)    收藏  举报