重新学习数据库(3)

单元概述

通过本章的学习能够理解MySQL数据库中分组查询的含义,掌握常用分组函数的使用,掌握GROUP BY子句的使用规则,掌握分组后数据结果的条件过滤,掌握SELECT语句执行过程,理解子查询的含义,掌握单行子查询和多行子查询的使用

测试数据脚本:

drop TABLE emp;
drop TABLE dept;
drop TABLE salgrade;
create table dept
(
deptno integer(4) not null,
dname varchar(14),
loc varchar(13)
);
alter table dept add constraint pk_dept primary key (deptno);
create table emp
(
empno integer(4) not null,
ename varchar(10),
job varchar(9),
mgr integer(4),
hiredate date,
sal decimal(7,2),
comm decimal(7,2),
deptno integer(2)
);
alter table emp add constraint pk_emp primary key (empno);
alter table emp add constraint fk_deptno foreign key (deptno) references dept (deptno);
create table salgrade
(
grade integer(1),
losal decimal(7,2),
hisal decimal(7,2)
);
insert into DEPT (DEPTNO, DNAME, LOC) values (10, ‘ACCOUNTING’, ‘NEW YORK’);
insert into DEPT (DEPTNO, DNAME, LOC) values (20, ‘RESEARCH’, ‘DALLAS’);
insert into DEPT (DEPTNO, DNAME, LOC) values (30, ‘SALES’, ‘CHICAGO’);
insert into DEPT (DEPTNO, DNAME, LOC) values (40, ‘OPERATIONS’, ‘BOSTON’);
insert into SALGRADE (GRADE, LOSAL, HISAL) values (1, 700, 1200);
insert into SALGRADE (GRADE, LOSAL, HISAL) values (2, 1201, 1400);
insert into SALGRADE (GRADE, LOSAL, HISAL) values (3, 1401, 2000);
insert into SALGRADE (GRADE, LOSAL, HISAL) values (4, 2001, 3000);
insert into SALGRADE (GRADE, LOSAL, HISAL) values (5, 3001, 9999);
— 下面要特别注意,%d-%m-%Y 里的 d 和 m 一定要小写
insert into EMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values (7369, ‘SMITH’, ‘CLERK’, 7902, STR_TO_DATE(’17-12-1980′, ‘%d-%m-%Y’), 800.00, null, 20);
insert into EMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values (7499, ‘ALLEN’, ‘SALESMAN’, 7698, STR_TO_DATE(’20-02-1981′, ‘%d-%m-%Y’), 1600.00, 300.00, 30);
insert into EMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values (7521, ‘WARD’, ‘SALESMAN’, 7698, STR_TO_DATE(’22-02-1981′, ‘%d-%m-%Y’), 1250.00, 500.00, 30);
insert into EMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values (7566, ‘JONES’, ‘MANAGER’, 7839, STR_TO_DATE(’02-04-1981′, ‘%d-%m-%Y’), 2975.00, null, 20);
insert into EMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values (7654, ‘MARTIN’, ‘SALESMAN’, 7698, STR_TO_DATE(’28-09-1981′, ‘%d-%m-%Y’), 1250.00, 1400.00, 30);
insert into EMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values (7698, ‘BLAKE’, ‘MANAGER’, 7839, STR_TO_DATE(’01-05-1981′, ‘%d-%m-%Y’), 2850.00, null, 30);
insert into EMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values (7782, ‘CLARK’, ‘MANAGER’, 7839, STR_TO_DATE(’09-06-1981′, ‘%d-%m-%Y’), 2450.00, null, 10);
insert into EMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values (7788, ‘SCOTT’, ‘ANALYST’, 7566, STR_TO_DATE(’19-04-1987′, ‘%d-%m-%Y’), 3000.00, null, 20);
insert into EMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values (7839, ‘KING’, ‘PRESIDENT’, null, STR_TO_DATE(’17-11-1981′, ‘%d-%m-%Y’), 5000.00, null, 10);
insert into EMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values (7844, ‘TURNER’, ‘SALESMAN’, 7698, STR_TO_DATE(’08-09-1981′, ‘%d-%m-%Y’), 1500.00, 0.00, 30);
insert into EMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values (7876, ‘ADAMS’, ‘CLERK’, 7788, STR_TO_DATE(’23-05-1987′, ‘%d-%m-%Y’), 1100.00, null, 20);
insert into EMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values (7900, ‘JAMES’, ‘CLERK’, 7698, STR_TO_DATE(’03-12-1981′, ‘%d-%m-%Y’), 950.00, null, 30);
insert into EMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values (7902, ‘FORD’, ‘ANALYST’, 7566, STR_TO_DATE(’03-12-1981′, ‘%d-%m-%Y’), 3000.00, null, 20);
insert into EMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values (7934, ‘MILLER’, ‘CLERK’, 7782, STR_TO_DATE(’23-01-1982′, ‘%d-%m-%Y’), 1300.00, null, 10);

高级查询单元练习:

  1. 查询部门20的员工,每个月的工资总和及平均工资。
    SELECT SUM(sal),AVG(sal)
    FROM emp
    WHERE deptno = 20;
  2. 查询工作在CHICAGO的员工人数,最高工资及最低工资。
    SELECT COUNT(*),MAX(sal),MIN(sal)
    FROM emp e,dept d
    WHERE e.deptno = d.deptno
    AND d.loc = ‘CHICAGO’;
  3. 查询员工表中一共有几种岗位类型。
    SELECT COUNT(DISTINCT job)
    FROM emp;

select job
from emp
group by job;

  1. 查询每个部门的部门编号,部门名称,部门人数,最高工资,最低工资,工资总和,平均工资。
    SELECT d.deptno,d.dname,COUNT(*),MAX(e.sal),MIN(e.sal),SUM(e.sal),AVG(e.sal)
    FROM emp e
    JOIN dept d
    ON e.deptno=d.deptno
    GROUP BY deptno;
  2. 查询每个部门,每个岗位的部门编号,部门名称,岗位名称,部门人数,最高工资,最低工资,工资总和,平均工资。
    select d.deptno,d.dname,e.job,count(*),max(e.sal),min(e.sal),sum(e.sal),avg(e.sal)
    from emp e,dept d
    where e.deptno=d.deptno
    group by d.deptno,d.dname,e.job;
  3. 查询每个经理所管理的人数,经理编号,经理姓名,要求包括没有经理的人员信息。
    SELECT COUNT(*),m.empno,m.ename
    FROM emp e
    LEFT outer JOIN emp m
    ON e.mgr=m.empno
    GROUP BY m.empno;

  4. 查询部门人数大于2的部门编号,部门名称,部门人数。
    SELECT d.deptno,d.dname,COUNT()
    FROM emp e,dept d
    WHERE e.deptno = d.deptno
    GROUP BY d.deptno
    HAVING COUNT(
    )>2;

select d.deptno,d.dname,count()
from emp e
right outer join dept d
on e.deptno=d.deptno
group by d.deptno,d.dname
having count(
)>2;
2. 查询部门平均工资大于2000,且人数大于2的部门编号,部门名称,部门人数,部门平均工资,并按照部门人数升序排序
SELECT d.deptno,d.dname,COUNT(),AVG(sal)
FROM emp e,dept d
WHERE e.deptno = d.deptno
GROUP BY d.deptno
HAVING COUNT(
)>2 AND AVG(sal)>2000
ORDER BY COUNT(*) ASC;

select d.deptno,d.dname,count(),avg(e.sal)
from emp e
right outer join dept d
on e.deptno=d.deptno
group by d.deptno,d.dname
having avg(e.sal)>2000 and count(
)>2
order by count(*);

  1. 查询入职日期最早的员工姓名,入职日期
    SELECT ename,hiredate
    FROM emp
    WHERE hiredate = (SELECT MIN(hiredate) FROM emp);
  2. 查询工资比SMITH工资高并且工作地点在CHICAGO的员工姓名,工资,部门名称
    SELECT e.ename,e.sal,d.dname
    FROM emp e,dept d
    WHERE e.deptno = d.deptno
    AND e.sal>(SELECT sal FROM emp WHERE emp.ename = ‘SMITH’)
    AND d.loc = ‘CHICAGO’;
  3. 查询入职日期比20部门入职日期最早的员工还要早的员工姓名,入职日期
    SELECT ename,hiredate
    FROM emp
    WHERE hiredate

Original: https://www.cnblogs.com/Aegeansea666/p/16484422.html
Author: Aegeansea666
Title: 重新学习数据库(3)

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/622769/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • 使用postman Mock后端响应

    使用postman Mock后端响应 接口文档开发与评审后,前后端各自依照标准进行开发,此时前端人员有以下选择: 使用工具自己mock构造后端数据验证已开发页面 在项目中自己编写添…

    数据库 2023年6月6日
    0155
  • ShardingSphere 异构迁移最佳实践:将3.5亿量级的顾客系统 RTO 减少60倍

    Apache ShardingSphere 助力当当 3.5 亿用户量级顾客系统重构,由 PHP+SQL Server 技术栈无缝转型为 Java+ShardingSphere+M…

    数据库 2023年5月24日
    0140
  • 数据库多表查询 联合查询 增删改查

    插入 方式一 语法: insert into 表名 (字段名,…) values (值,…); 特点: 1、要求值的类型和字段的类型要一致或兼容 2、字段的个数和顺序不一定…

    数据库 2023年6月16日
    0205
  • 浅谈事务隔离级别、MVCC及相关特性

    文采不是太好,应该会有地方表达不清楚,烦请指正。 需要事先准备测试表: CREATE TABLE test ( id int(11) NOT NULL, name varchar(…

    数据库 2023年6月16日
    0133
  • StoneDB(石原子科技)受邀参与《开源数据库服务商服务能力分级要求》标准第一次讨论会

    2022年8月9日下午,StoneDB数据库主体研发单位石原子科技与华为、openGauss开源社区、云和恩墨、甲骨文等组织受邀参与《开源数据库服务商服务能力分级要求》标准第一次讨…

    数据库 2023年5月24日
    0130
  • 03-MySQL事务

    数据库事务 1、事务特性 1.1、原子性 即不可分割性,事务要么全部被执行,要么就全部不被执行 1.2、一致性 事务的执行使得数据库从一种正确状态转换成另一种正确状态 1.3、隔离…

    数据库 2023年6月16日
    0159
  • linux根目录无法查看文件执行ls卡死无反应执行df -h 也同样没反应的处理方法

    问题现象: 1、执行 df -h 卡死没反应,执行 df -hl 可以正常显示; 2、执行  ll / 或 ls /&…

    数据库 2023年6月11日
    0131
  • git本地分支推送至远程分支

    1、本地任意盘→新建文件夹,例:我新建文件夹名称是:E:\git 2、打开git文件夹,文件夹内鼠标右击选择 Git Bash Here 3、克隆远程分支到本地分支【远程分支移动到…

    数据库 2023年6月14日
    0223
  • JWT简介

    JWT简介 在用户注册或登录后,我们想记录用户的登录状态,或者为用户创建身份认证的凭证。我们不再使用Session认证机制,而使用Json Web Token认证机制。 (1) 什…

    数据库 2023年6月14日
    0153
  • django中的视图层

    1.什么是视图层 简单来说,就是用来接收路由层传来的请求,从而做出相应的响应返回给浏览器 2.视图层的格式与参数说明 2.1基本格式 from django.http import…

    数据库 2023年6月14日
    0127
  • Vmware 虚拟机连接外网和设置固定IP

    NAT 模式(地址转换模式) 在NAT模式中,主机网卡直接与虚拟NAT设备相连,然后虚拟NAT设备与虚拟DHCP服务器一起连接在虚拟交换机VMnet8上,虚拟机借助NAT功能,通过…

    数据库 2023年6月14日
    0164
  • Go语言常见的并发模式

    Go语言常见的并发模式 并发不是并行 并发关注的是程序的设计层面,并发的程序也可以顺序执行,在多核CPU上才可能真正同时的运行,并行关注的是程序的运行层面,如GPU中对图像处理都会…

    数据库 2023年6月16日
    0121
  • 回溯问题学习总结

    回溯问题 三种情况 每种情况都有子集,组合,排列三种题型 无重复元素不可复选 //子集问题 …

    数据库 2023年6月16日
    0132
  • 一段文字

    https://book.douban.com/review/13674387/现代人的困境,其实从出生开始每个人都有强烈的感受。我们会按户口管理,强调身份的是各种标签,各种统计数…

    数据库 2023年6月11日
    0116
  • MySQL 关于 only_full_group_by 限制

    先上结论 如果 only_full_group_by 被启用,那么在查询时,如果某个列不在group by 列表中,此时如果不对该列进行聚合处理,则该列不能出现在 select 列…

    数据库 2023年6月16日
    0161
  • RadonDB MySQL Kubernetes 2.2.0 发布!

    摘要 RadonDB MySQL Kubernetes v2.2.0 于近日发布!该版本开始支持 MySQL 8.0,备份功能优化,并全面提升高可用稳定性。社区同步发起&#8221…

    数据库 2023年5月24日
    0163
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球