转载 原文地址

建表

在这里我们先建立两张有外键关联的两张表:

  1. CREATE DATABASE db0206;
  2. USE db0206;
  3. CREATE TABLE `db0206`.`tbl_dept`(
  4. `id` INT(11) NOT NULL AUTO_INCREMENT,
  5. `deptName` VARCHAR(30),
  6. `locAdd` VARCHAR(40),
  7. PRIMARY KEY (`id`)
  8. ) ENGINE=INNODB CHARSET=utf8;
  9. CREATE TABLE `db0206`.`tbl_emp`(
  10. `id` INT(11) NOT NULL AUTO_INCREMENT,
  11. `name` VARCHAR(20),
  12. `deptId` INT(11),
  13. PRIMARY KEY (`id`),
  14. FOREIGN KEY (`deptId`) REFERENCES `db0206`.`tb_dept`(`id`)
  15. ) ENGINE=INNODB CHARSET=utf8;
  16. /*插入数据*/
  17. INSERT INTO tbl_dept(deptName,locAdd) VALUES('RD',11);
  18. INSERT INTO tbl_dept(deptName,locAdd) VALUES('HR',12);
  19. INSERT INTO tbl_dept(deptName,locAdd) VALUES('MK',13);
  20. INSERT INTO tbl_dept(deptName,locAdd) VALUES('MIS',14);
  21. INSERT INTO tbl_dept(deptName,locAdd) VALUES('FD',15);
  22. INSERT INTO tbl_emp(NAME,deptId) VALUES('z3',1);
  23. INSERT INTO tbl_emp(NAME,deptId) VALUES('z4',1);
  24. INSERT INTO tbl_emp(NAME,deptId) VALUES('z5',1);
  25. INSERT INTO tbl_emp(NAME,deptId) VALUES('w5',2);
  26. INSERT INTO tbl_emp(NAME,deptId) VALUES('w6',2);
  27. INSERT INTO tbl_emp(NAME,deptId) VALUES('s7',3);
  28. INSERT INTO tbl_emp(NAME,deptId) VALUES('s8',4);

Venn图与SQL语句的编写以及查询结果

1. 内连接

内连接Venn图

执行的SQL语句以及执行的查询结果:

  • 执行的SQL语句

    select * from tbl_dept a inner join tbl_emp b on a.id=b.deptId;
  • 查询结果

2. 左外连接

左外连接文氏图:

执行的sql语句以及执行的查询结果:

  • 执行的sql语句

    select * from tbl_dept a left join tbl_emp b on a.id=b.deptId;
  • 查询结果

3. 右外连接

右外连接Venn图:

执行的sql语句以及执行的查询结果

  • 执行的sql语句

    select * from tbl_dept a right join tbl_emp b on a.id=b.deptId
  • 查询结果

4. 左连接

左连接Venn图:

执行的SQL语句以及执行的查询结果

  • 执行的sql语句

    select * from tbl_dept a left join tbl_emp b on a.id=b.deptId where b.deptId is null;
  • 查询结果

5. 右连接

右连接文氏图

执行的sql语句以及执行的查询结果:

  • 执行的sql语句

    select * from tbl_dept a right join tbl_emp b on a.id=b.deptId where a.id is null;
  • 查询结果

6. 全连接

全连接文氏图:

执行的sql语句以及执行的查询结果:

  • 执行的sql语句
  1. select * from tbl_dept a right join tbl_emp b on a.id=b.deptId
  2. union
  3. select * from tbl_dept a left join tbl_emp b on a.id=b.deptId;
  • 查询结果

7. 两张表中都没有出现的数据集

文氏图:

执行的sql语句以及执行的查询结果:

  • 执行的sql语句
  1. select * from tbl_dept a right join tbl_emp b on a.id=b.deptId where a.id is null union select * from tbl_dept a left join tbl_emp b on a.id=b.deptId where b.deptId is null;
  • 查询结果

MySQL的七种join的更多相关文章

  1. MySQL 的七种 join

    建表 在这里呢我们先来建立两张有外键关联的张表. CREATE DATABASE db0206; USE db0206; CREATE TABLE `db0206`.`tbl_dept`( `id` ...

  2. MYSQL 的七种join

    建表 在这里呢我们先来建立两张有外键关联的张表. CREATE DATABASE db0206; USE db0206; CREATE TABLE `db0206`.`tbl_dept`( `id` ...

  3. 【知识库】-数据库_MySQL 的七种 join

    掘金作者:haifeisi 文章出处: MySQL 的七种 join Learn [已经过测试校验] 一.内连接 二.左外连接 三.右外连接 四.左连接 五.右连接 六.全连接 七.两张表中都没有出现 ...

  4. MySQL逻辑架构、SQL加载执行顺序、七种JOIN模式图解

    逻辑架构   存储引擎 查看当前安装的mysql提供的存储引擎 查看当前mysql默认的存储引擎 MyISAM和InnoDB SQL加载执行顺序 sql书写顺序 mysql解析器执行的顺序  考点:m ...

  5. Mysql七种 JOIN 连接

    内连接 SELECT <select_list> FROM TableA A INNER JOIN TableB B ON A.Key = B.Key 左外连接 SELECT <se ...

  6. MySQL七种join理论

    1. 内连接 select * from A inner join B where A.key=B.key; 2. 左连接 select * from A left join B on A.key=B ...

  7. 七种join的书写规范

    在mysql中的两表进行连接时,总共有7种连接情况,具体可见下图 由图的从左到右的顺序 图1.左连接(left join):返回左表中的所有记录和右表中的连接字符字段相等的记录,若右表没有匹配值则补N ...

  8. MySQL 的七种日志总结

    文章转载自:https://mp.weixin.qq.com/s/ewv7HskHvH3O7kFyOmoqgw 一.MySQL 日志分类 日志类别 说明 备注 错误日志 错误日志记录了当MySQL启动 ...

  9. 1. 七种join的sql编写

    一.join图 二.sql演示 a.创建演示表及数据 SET NAMES utf8mb4; SET FOREIGN_KEY_CHECKS = 0; -- ----------------------- ...

随机推荐

  1. 洛谷 P2258 子矩阵 解题报告

    P2258 子矩阵 题目描述 给出如下定义: 子矩阵:从一个矩阵当中选取某些行和某些列交叉位置所组成的新矩阵(保持行与列的相对顺序)被称为原矩阵的一个子矩阵. 例如,下面左图中选取第 2 . 4行和第 ...

  2. webpack css压缩方案

    css-loader原有的minimize选项在1.0.0版本已经移除,不能使用其进行css压缩. 目前可行的css压缩方案有: 1. postcss-loader with cssnano or u ...

  3. Redis 的安装配置介绍

    redis 是一个高性能的key-value数据库. redis的出现,很大程度补偿了memcached这类keyvalue存储的不足,在部 分场合可以对关系数据库起到很好的补充作用.它提供了Pyth ...

  4. CCPC-Winter Camp div2 day1

    A:机器人 传送门:https://www.zhixincode.com/contest/1/problem/A 题意:地图是由A.B两根线组成的,机器人一开始是在A线上的S点,他初始时可以选择任意方 ...

  5. js:鼠标移动到文字显示div,移出文字div显示,鼠标能移进div

    <!DOCTYPE html><html lang="en"> <head> <meta charset="UTF-8" ...

  6. sublime 常用插件 感觉比较全了 够用了

    插件介绍 Package Control 功能:安装包管理 简介:sublime插件控制台,提供添加.删除.禁用.查找插件等功能 使用:https://sublime.wbond.net/instal ...

  7. html 让一行文字居中

    文本在行高范围内垂直居中 可以利用行高特性让一行文本居中 line-height:100px://父容器的高度

  8. zoj 1729 Hidden Password

    Hidden Passwordhttp://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=729 Time Limit: 2 Seconds ...

  9. jedis,spring-redis-data 整合使用,版本问题异常

    jedis,spring-redis-data 整合使用,版本不匹配的时候经常会报一些异常,例如1: java.lang.NoClassDefFoundError: org/springframewo ...

  10. jQuery简单的Ajax调用

    index.php 的代码如下: <!DOCTYPE HTML> <html> <head> <meta charset="UTF-8"& ...