重新学习数据库(2)

单元概述

通过本章的学习能够了解MySQL数据库中多表查询的含义,掌握多表查询的基本写法,掌握特殊的多表查询的写法,掌握内连接和外连接的区别

测试数据脚本

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. 写一个查询,显示所有员工姓名,部门编号,部门名称。
    SELECT e.ename,e.deptno,d.dname
    FROM emp e, dept d
    WHERE e.deptno = d.deptno;
  2. 写一个查询,显示所有工作在CHICAGO并且奖金不为空的员工姓名,工作地点,奖金
    SELECT e.ename,d.loc,e.comm
    FROM emp e,dept d
    WHERE e.deptno = d.deptno
    AND e.comm is not NULL
    AND d.loc = ‘CHICAGO’;
  3. 写一个查询,显示所有姓名中含有A字符的员工姓名,工作地点。
    SELECT e.ename,d.loc
    FROM emp e, dept d
    WHERE e.deptno =d.deptno
    AND ename LIKE ‘%A%’;

1.查询每个员工的编号,姓名,工资,工资等级,所在工作城市,按照工资等级进行升序排序
SELECT e.empno,e.ename,e.sal,s.grade,d.loc
FROM emp e,dept d,salgrade s
WHERE e.deptno = d.deptno
AND (e.sal BETWEEN s.losal AND s.hisal)
ORDER BY grade ASC;

1.查询所有工作在NEW YORK和CHICAGO的员工姓名,员工编号,以及他们的经理姓名,经理编号
SELECT worker.ename ‘ENAME’,worker.empno ‘ENO’,manager.ename ‘MNAME’,manager.empno ‘MNO’
FROM emp worker,emp manager,dept d
WHERE worker.mgr = manager.empno
AND worker.deptno = d.deptno
AND d.loc IN (‘NEW YORK’,’CHICAGO’);

  1. 创建一个员工表和部门表的交叉连接。
    select * from emp cross join dept;
  2. 使用自然连接,显示入职日期在80年5月1日之后的员工姓名,部门名称,入职日期
    SELECT e.ename,e.deptno,e.hiredate
    FROM emp e NATURAL JOIN dept d
    WHERE hiredate >’1980-05-01′;
  3. 使用左连接,查询每个员工的姓名,经理姓名,没有经理的King也要显示出来。
    SELECT worker.ename ‘WNAME’,manager.ename ‘MNAME’
    FROM emp worker
    LEFT OUTER JOIN emp manager
    ON (worker.mgr = manager.empno);
  4. 使用右连接,查询每个员工的姓名,经理姓名,没有经理的King也要显示出来
    SELECT worker.ename ‘WNAME’,manager.ename ‘MNAME’
    FROM emp manager
    RIGHT OUTER JOIN emp worker
    ON (worker.mgr = manager.empno);

课后练习

  1. 显示员工SMITH的姓名,部门名称,直接上级名称
    SELECT worker.ename ‘WNAME’,d.dname ‘DNAME’,manager.ename ‘MNAME’
    FROM emp worker,dept d,emp manager
    WHERE worker.mgr = manager.empno
    AND worker.deptno = d.deptno
    AND worker.ename = ‘SMITH’;
  2. 显示员工姓名,部门名称,工资,工资级别,要求工资级别大于4级。
    SELECT e.ename,d.dname,e.sal,s.grade
    FROM emp e, dept d,salgrade s
    WHERE e.deptno = d.deptno
    AND(e.sal BETWEEN s.losal AND s.hisal)
    AND s.grade > 4;
  3. 显示员工KING和FORD管理的员工姓名及其经理姓名。
    SELECT e.ename “员工姓名”,m.ename “经理姓名”
    FROM emp e,emp m
    WHERE e.mgr=m.empno
    AND m.ename =’KING’ or e.mgr=m.empno and m.ename =’FORD’;
  4. 显示员工姓名,参加工作时间,经理名,参加工作时间,要求参加时间比经理早
    SELECT e.ename “员工姓名”, e.hiredate “参加工作时间” ,m.ename “经理姓名”, m.hiredate “经理参加工作时间”
    FROM emp e,emp m
    WHERE e.mgr=m.empno

对等值连接、不等值连接、自身连接、外连接有了更深刻的理解,查询语句写得更加熟练了

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

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

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

(0)

大家都在看

  • mysql数据库 Window下安装

    关系数据库,是建立在关系数据库模型基础上的数据库,借助于集合代数等概念和方法来处理数据 库中的数据,同时也是一个被组织成一组拥有正式描述性的表格,该形式的表格作用的实质是装载着数 …

    数据库 2023年6月9日
    0102
  • 数据库设计案例

    简单构建设计数据库 数据库设计案例 描述:简单构建设计数据库 sql代码实现 /* 数据库设计案例 */ — 音乐表 CREATE TABLE Music ( title VAR…

    数据库 2023年5月24日
    0123
  • 线程的同步

    线程同步机制同步块:Java中提供了同步机制,可以有效的防止资源冲突。同步机制使用 synchronized关键字 使用该关键字的代码块称为同步块。同步块 语法: synchron…

    数据库 2023年6月16日
    0127
  • Collections.singletonList方法

    这个方法主要用于只有一个元素的优化, 减少内存分配,无需分配额外的内存,可以从SingletonList内部类看得出来,由于只有一个element,因此可以做到内存分配最小化,相比…

    数据库 2023年6月16日
    086
  • 创建镜像(alpine版)+alpine

    podman用脚本和dockerfile做apache编译安装镜像 1.0安装介质 2.0 特点 2.0 基础命令 3.0 模式 podman用脚本和dockerfile做apac…

    数据库 2023年6月14日
    0104
  • 得体的注释,让我总能想起TA

    作为一个技术TL,在排查生产问题时,我经常要周转于各个工程里。系统和服务多起来后,要我了解每一段代码具体的来龙去脉逐渐几乎不可能了。 例如,今天,我要查一下调用某个三方接口所配置的…

    数据库 2023年6月9日
    0176
  • 【数据库】– MySQL SQL调优笔记(2)

    1.常规索引优化方式 1.1.单表优化 查询category_id为1且comments大于1的情况下,views最多的article id SELECT id, author_i…

    数据库 2023年5月24日
    083
  • 设计模式之(6)——建造者模式

    定义:建造者模式也称为生成器模式,将一个个简单对象一步步构造成一个复杂的对象,将复杂对象的构建和它的表示分离,使得同样的构建过程有不同的表示; 主要解决:系统中复杂对象的创建过程,…

    数据库 2023年6月14日
    079
  • Linux–>shell

    shell是什么 Shell是一个命令行解释器,它为用户提供了一个向Linux内核发送请求以便运行程序的界面系统级程序。 用户可以用Shell来启动,挂起,停止,编写一些程序。 S…

    数据库 2023年6月14日
    0109
  • 一文说透 MySQL JSON 数据类型(收藏)

    JSON 数据类型是 MySQL 5.7.8 开始支持的。在此之前,只能通过字符类型(CHAR,VARCHAR 或 TEXT )来保存 JSON 文档。 相对字符类型,原生的 JS…

    数据库 2023年5月24日
    081
  • SQL语句的整合

    基础语法 https://blog.csdn.net/m0_37989980/article/details/103413942 CRUD 提供给数据库管理员的基本操作,CRUD(…

    数据库 2023年6月14日
    077
  • 阿里云智能客服机器人,自定义函数调用配置

    说明:也是没有段子的一天…..在没有段子的日子里….我们来研究下阿里云的客服机器人…. 一、功能调查 官网地址:https://help.ali…

    数据库 2023年6月6日
    0131
  • 心态崩了,我怎么知道实际生产环境的 B+ 树索引有多少层?

    Q:在实际生产环境中,InnoDB 中一棵 B+ 树索引一般有多少层?可以存放多少行数据? 关于这个问题最近好像在牛客上经常看到,感觉没啥意义,可能主要考察的是对 B+ 索引的理解…

    数据库 2023年6月6日
    0100
  • MySQL45讲之生产环境下的性能问题

    本文介绍了一些常见的性能问题以及如何在生产环境中解决这些问题。 [En] This article introduces some common performance probl…

    数据库 2023年5月24日
    0111
  • Golang 接口(interface)

    Go 语言的接口遵守LSP(里氏替换原则),即 一个类型可以自由地被另一个满足相同接口的类型替换。 接口类型具体描述了一系列方法的集合,一个实现了这些方法的具体类型是这个接口类型的…

    数据库 2023年6月16日
    077
  • Nginx进阶篇—web模块及proxy代理

    server { #在server{下面输入 sub_filter n…

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