清晰讲解SQL语句中的外连接,通用于Mysql和Oracle,全是干货哦

直入主题:

我们做一个操作,将员工SCOTT的部门去掉,再次通过内连接查看数据,看看会产生什么现象?

使用内连接,查询数据

问题:找不到SCOTT员工了,只有13条数据,这显然不合理;这就是内连接的缺点

-- 内连接:只显示匹配的数据

-- 外连接:显示匹配的数据,还显示(部分或者全部)不匹配的数据,那就是显示(全部)的数据

(1)左外连接:left join

特点:左表全部显示,包括不匹配的数据,右表进行匹配显示

(2)右外连接:right join

右表全部显示,包括不匹配的数据,左表进行匹配显示

(3)全外连接

左表和右表的数据都会显示,包括不匹配的数据

注意:在oracle中支持full join

在mysql中不支持全外连接,但是,可以通过union 连接左外连接和右外连接,达到全外连接的效果

(4)自连接

思路:将一张表看做两张表 下级表 上级表

举例:显示没有上级的员工(king)

知识扩展:

三表查询:

就是先查两张表,将查出的结果看成一张表,然后跟第三张表进行联合查询,本质还是两表查询

准备工作:先添加一张薪资等级表

第一步:连接emp和dept表

查询员工的编号、姓名、薪水、部门编号、部门名称

第二步:连接第三张表

-- 查询员工的编号、姓名、薪水、部门编号、部门名称、薪水等级

至此,全部的表连接讲解完毕!

欢迎留言,指出问题,有则改之无则加勉

下面,分享所有的SQL语句:

复制代码

create table DEPT

(

DEPTNO int(2) not null,

DNAME VARCHAR(14),

LOC VARCHAR(13)

);

alter table DEPT

add constraint PK_DEPT primary key (DEPTNO);

create table EMP

(

EMPNO int(4) primary key,

ENAME VARCHAR(10),

JOB VARCHAR(9),

MGR int(4),

HIREDATE DATE,

SAL double(7,2),

COMM double(7,2),

DEPTNO int(2)

);

alter table EMP

add constraint FK_DEPTNO foreign key (DEPTNO)

references DEPT (DEPTNO);

create table SALGRADE

(

GRADE int primary key,

LOSAL double(7,2),

HISAL double(7,2)

);

create table BONUS

(

ENAME VARCHAR(10),

JOB VARCHAR(9),

SAL double(7,2),

COMM double(7,2)

);

commit;

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');

commit;

insert into EMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)

values (7369, 'SMITH', 'CLERK', 7902, '1980-12-17', 800, null, 20);

insert into EMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)

values (7499, 'ALLEN', 'SALESMAN', 7698, '1981-02-20', 1600, 300, 30);

insert into EMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)

values (7521, 'WARD', 'SALESMAN', 7698, '1981-02-22', 1250, 500, 30);

insert into EMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)

values (7566, 'JONES', 'MANAGER', 7839, '1981-04-02', 2975, null, 20);

insert into EMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)

values (7654, 'MARTIN', 'SALESMAN', 7698, '1981-09-28', 1250, 1400, 30);

insert into EMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)

values (7698, 'BLAKE', 'MANAGER', 7839, '1981-05-01', 2850, null, 30);

insert into EMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)

values (7782, 'CLARK', 'MANAGER', 7839, '1981-06-09', 2450, null, 10);

insert into EMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)

values (7788, 'SCOTT', 'ANALYST', 7566, '1987-04-19', 3000, null, 20);

insert into EMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)

values (7839, 'KING', 'PRESIDENT', null, '1981-11-17', 5000, null, 10);

insert into EMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)

values (7844, 'TURNER', 'SALESMAN', 7698, '1981-09-08', 1500, 0, 30);

insert into EMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)

values (7876, 'ADAMS', 'CLERK', 7788, '1987-05-23', 1100, null, 20);

insert into EMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)

values (7900, 'JAMES', 'CLERK', 7698, '1981-12-03', 950, null, 30);

insert into EMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)

values (7902, 'FORD', 'ANALYST', 7566, '1981-12-03', 3000, null, 20);

insert into EMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)

values (7934, 'MILLER', 'CLERK', 7782, '1982-01-23', 1300, null, 10);

commit;

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);

commit;

复制代码

复制代码

-- 一、内连接

-- 交叉连接 cross JOIN

-- 笛卡尔积现象

SELECT *

FROM emp

CROSS JOIN dept;

-- 使用using,只显示指定的同名字段

SELECT *

FROM emp e

CROSS JOIN dept d

USING (deptno);

-- 使用on,指定不同名的字段

SELECT *

FROM emp e

CROSS JOIN dept d

ON(e.deptno = d.deptno);

-- natural join 自然连接 所有同名列只显示一次

SELECT *

FROM emp

NATURAL JOIN dept;

-- 二、外连接

-- 左外连接 emp左表,dept 右表,左表全部显示,包括没有数据的列

SELECT *

FROM emp e -- 左表

LEFT JOIN dept d -- 右表

on(e.deptno = d.deptno);

-- 右外连接 emp左表, dept右表,右表全部显示,包括没有数据的列

SELECT *

FROM emp e -- 左表

RIGHT JOIN dept d -- 右表

on(e.deptno = d.deptno);

-- 全外连接 ,oracle支持,mysql不支持

-- 可以通过关键字union进行解决,左表和右表的无对应数据列都会显示

SELECT *

FROM emp e

LEFT JOIN dept d

on(e.deptno = d.deptno);

UNION

SELECT *

FROM emp e

RIGHT JOIN dept d

on(e.deptno = d.deptno);

-- 三、三表查询

SELECT * FROM emp;

SELECT * FROM dept;

SELECT * FROM salgrade;

-- 第一步,先查两张表

SELECT e.empno,e.ename,e.sal,d.deptno,d.dname

FROM emp e

JOIN dept d

ON e.deptno = d.deptno;

-- 第二步,连接第三张表

SELECT e.empno, e.ename,e.sal,d.deptno,d.dname,sg.grade

FROM emp e

JOIN dept d

ON e.deptno = d.deptno

JOIN salgrade sg

ON e.sal BETWEEN sg.losal AND sg.hisal;

-- 四、自连接

-- 不是所有表都可以进行自连接,只有表中的两列有关联关系,才可以进行自连接查询

-- 将自身分解成两张表

SELECT e.empno,e.ename,e.mgr,m.empno,m.ename

FROM emp e

LEFT JOIN emp m

ON e.mgr = m.empno;

复制代码

mysql与orancl_清晰讲解SQL语句中的外连接,通用于Mysql和Oracle,全是干货哦相关推荐

  1. oracle 哦【的【,清晰讲解SQL语句中的外连接,通用于Mysql和Oracle,全是干货哦

    清晰讲解SQL语句中的外连接,通用于Mysql和Oracle,全是干货哦 直入主题: 我们做一个操作,将员工SCOTT的部门去掉,再次通过内连接查看数据,看看会产生什么现象? 使用内连接,查询数据 问 ...

  2. 清晰讲解SQL语句中的外连接,通用于Mysql和Oracle,全是干货哦

    直入主题: 我们做一个操作,将员工SCOTT的部门去掉,再次通过内连接查看数据,看看会产生什么现象? 使用内连接,查询数据 问题:找不到SCOTT员工了,只有13条数据,这显然不合理:这就是内连接的缺 ...

  3. groovy怎样从sql语句中截取表名_sql注入mysql篇

    SQL注入 __0x01 ♛Sql注入原理 Sql注入顾名思义是没有对用户输入的参数进行过滤导致测试者可以将一段非正常语句插入到查询语句中,由web应用带入到数据库中执行,从而读取数据库中的数据. _ ...

  4. mysql groupby having_浅谈sql语句中GROUP BY 和 HAVING的使用方法

    在介绍GROUP BY 和 HAVING 子句前,我们必需先讲讲sql语言中一种特殊的函数:聚合函数, 例如SUM, COUNT, MAX, AVG等.这些函数和其它函数的根本区别就是它们一般作用在多 ...

  5. SQL语句中不同的连接JOIN

    为了从两个表中获取数据,我们有时会用JOIN将两个表连接起来.通常有以下几种连接方式: JOIN  or  INNER JOIN(内连接) : 这两个是相同的,要求两边表同时有对应的数据,返回行,任何 ...

  6. mysql char转int_在sql语句中怎样把char类型转换成int类型?

    展开全部 首先char类型的必须是数字,将字符的数32313133353236313431303231363533e58685e5aeb931333431373262字转成数字,比如'0'转成0可以直 ...

  7. MS SQL 语句中的字符串连接

    在MS SqlServer中,需要将几个字段或是几个值连接作为一个字符串值输出时,可以使用"+"字符串连接符来连接即可,如: DECLARE @a nvarchar(30),@b  ...

  8. sql语句中的limit用法

    sql语句中的limit用法 limit 用于限制查询结果返回. 用法: limit a,b 其中a表示查询数据的起始位置,b表示返回的数量. (MySQL数据库中的记录是从0开始的) 举例: SEL ...

  9. mysql host %s_python mysql:虽然%s和列匹配,但并非SQL语句中使用的所有参数

    PythonMySQL.connector一直给我错误不是SQL语句中使用的所有参数.这是我的代码:import mysql.connector con = mysql.connector.Conne ...

最新文章

  1. Kafka日志清理之Log Deletion
  2. 前端学习(2225):react之类定义组件
  3. MySQL Connector/C++入门教程(上)
  4. EKF_SLAM一般过程
  5. Oracle12c用户名scott,Oracle12c新特性pdborcl,如何登录到普通用户scott ?
  6. shell脚本编写九九乘法表_Shell脚本:打印九九乘法表
  7. python爬取ajax_Python爬虫如-何爬取ajax网页之爬取雪球网文章
  8. 【NDN IoT】NDN-ACE: Access Control for Constrained Environments over Named Data Networking 全文翻译
  9. React基础(貳)———组件
  10. Python开发图形可视化界面程序(一)
  11. 【Leetcode】1335. Minimum Difficulty of a Job Schedule
  12. eclipse 个性化设置 绿色护眼
  13. PNET的桥接与CRT合并窗口
  14. 物业管理系统 ERP系统 下载
  15. PSIM仿真简单例程(频率响应)
  16. 基于Apriori算法的网上图书销售ssm java毕业设计
  17. Spring框架核心之(一)Spring简介
  18. 可微偏导数一定存在_函数可微,那么偏导数一定存在,且连续吗?
  19. 什么是同源策略及解决跨域的三种方式
  20. JavaScript BMI指数判断

热门文章

  1. SpringMVC 集成 mybatisPlus 分析
  2. python使用PyMysql连接MySQL实现增删改查
  3. HTTP状态码415 springboot项目
  4. 傅里叶变换处理sar图像_SAR和ISAR雷达的基础知识
  5. 黑苹果找不到触控板_猫和老鼠手游:好友位不足却找不到人开黑?玩家给好友系统支招...
  6. GPUImage – 亮度平均 GPUImageLuminosity
  7. Python chr 函数 - Python零基础入门教程
  8. pythonsocket中tcp通信接收不到数据_TCP 为什么三次握手而不是两次握手(正解版)...
  9. anaconda 安装pytorch_conda上安装PyTorch
  10. 比特协议是骗局吗_山寨币也玩收割,“BTG比特黄金”挖矿骗局大揭秘