iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >MySQL JOIN的使用
  • 402
分享到

MySQL JOIN的使用

MySQLJOIN的使用 2017-12-31 07:12:37 402人浏览 绘本
摘要

JOIN的使用 JOIN 理论 Mysql 七种 JOIN 的 sql 编写 环境搭建 # 创建部门表 CREATE TABLE tbl_dept ( id INT NOT NULL AUTO_INCREMENT, deptNa

MySQL JOIN的使用

JOIN的使用

JOIN 理论

Mysql 七种 JOIN 的 sql 编写

环境搭建

# 创建部门表
CREATE TABLE tbl_dept (
  id INT NOT NULL AUTO_INCREMENT,
  deptName VARCHAR (30) DEFAULT NULL,
  locAdd VARCHAR (40) DEFAULT NULL,
  PRIMARY KEY (id)
) ENGINE = INNODB AUTO_INCREMENT = 1 DEFAULT chharset = utf8 ;

# 创建员工表
CREATE TABLE tbl_emp (
  id INT NOT NULL AUTO_INCREMENT,
  `name` VARCHAR (20) DEFAULT NULL,
  deptId INT (11) DEFAULT NULL,
  PRIMARY KEY (id),
  KEY fk_dept_id (deptId) CONSTRaiNT fk_dept_id FORREIGN KEY (deptId) REFERENCES tbl_dept (id)
) ENGINE = INNODB AUTO_INCREMENT = 1 DEFAULT CHARSET = uttf8 ;

# 插入部门信息
INSERT INTO tbl_dept(deptName,locAdd) VALUES("RD",11),("HR",12),("MK",13),("MIS",14),("FD",15);

# 插入员工信息
INSERT INTO tbl_emp(`name`,deptId) VALUES("z3",1),("z4",1),("z5",1),("w5",2),("w6",2),("s7",3),("s8",4),("s9",51);

1.内连接(INNER JOIN)

语句
SELECT * FROM tbl_dept a INNER JOIN tbl_emp b ON a.id = b.deptId;
有图有真相

理解
  • 可以理解为两个集合的交集

2.左(外)连接(LEFT JOIN)

语句
SELECT * FROM tbl_dept a LEFT JOIN tbl_emp b ON a.id = b.deptId;
有图有真相

理解
  • LEFT JOIN 返回左表的全部行和右表满足 ON 条件的行,如果左表的行在右表中没有匹配,那么这一行右表中对应数据用 NULL 代替

3.右(外)连接(RIGHT JOIN)

语句
SELECT * FROM tbl_dept a RIGHT JOIN tbl_emp b ON a.id = b.deptId;
有图有真相

理解
  • RIGHT JOIN 返回右表的全部行和左表满足 ON 条件的行,如果右表的行在左表中没有匹配,那么这一行左表中对应数据用 NULL 代替。

4.左表独有

语句
SELECT * FROM tbl_dept a LEFT JOIN tbl_emp b ON a.id = b.deptId WHERE b.deptId IS NULL;
有图有真相

理解
  • 查询左表独有的数据 (注意:左表独有,右表 key 为空)

5.右表独有

语句
SELECT * FROM tbl_dept a RIGHT JOIN tbl_emp b ON a.id = b.deptId WHERE a.id IS NULL;
有图有真相

理解
  • 查询右表独有的数据 (注意:右表独有,左表 key 为空)

6.全连接

语句
SELECT * FROM tbl_dept a LEFT JOIN tbl_emp b ON a.id = b.deptId 
UNION
SELECT * FROM tbl_dept a RIGHT JOIN tbl_emp b ON a.id = b.deptId;
有图有真相

理解
  • mysql 中不支持 FULL JOIN 进行全连接,可以用 一个左连接 UNioN 一个右连接

7.左右表独有

语句
SELECT * FROM tbl_dept a LEFT JOIN tbl_emp b ON a.id=b.deptId WHERE b.deptId IS NULL
UNION
SELECT * FROM tbl_dept a RIGHT JOIN tbl_emp b ON a.id=b.deptId WHERE a.id IS NULL;
有图有真相

理解
  • 左右表独有 = 左表独有 + 右表独有

我是阿廷,一个相信努力可以改变人生的人,我相信一切的上进行为都是值得的,至少可以让我看见更大的世界。
您可能感兴趣的文档:

--结束END--

本文标题: MySQL JOIN的使用

本文链接: https://www.lsjlt.com/news/8675.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL的join使用
    #内连接select * from auth_user u inner join auth_group g on u.id = g.id; #左连接select * from auth_user a left join...
    99+
    2015-08-21
    MySQL的join使用
  • MySQL JOIN的使用
    JOIN的使用 JOIN 理论 MySQL 七种 JOIN 的 SQL 编写 环境搭建 # 创建部门表 CREATE TABLE tbl_dept ( id INT NOT NULL AUTO_INCREMENT, deptNa...
    99+
    2017-12-31
    MySQL JOIN的使用
  • mysql中的join、left join和right join的用法
    本篇内容介绍了“mysql中的join、left join和right join的用法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大...
    99+
    2022-10-18
  • mysql中inner join和left join如何使用
    这篇文章主要介绍“mysql中inner join和left join如何使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“mysql中inner join和left&...
    99+
    2023-07-05
  • MySql中如何使用JOIN
    这篇文章将为大家详细讲解有关MySql中如何使用JOIN,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。JOIN的含义就如英文单词“join”一样,连接两张表,大致分为内连接,外连接,右连接,左连接,自然连...
    99+
    2023-06-29
  • MySQL多表查询内连接外连接详解,join、left join、right join、full join的使用
    目录 1、多表查询概览 1.1、分类 1.2、外连接的分类 1.3、常用的SQL语法标准 2、内外联接案例 2.1、初始化表 2.2、内连接 2.3、外连接案例 2.4、全连接案例 2.5、union和union all...
    99+
    2023-09-02
    mysql 数据库 java
  • MySQL七大JOIN的具体使用
    目录简介练习简介 A的独有+AB的公有B的独有+AB的公有AB的公有A的独有B的独有A的独有+B的独有+AB的公有A的独有+B的独有 练习 建表 部门表 DROP TABL...
    99+
    2022-11-13
  • Mysql 多表连接查询 inner join 和 outer join 的使用
      首先先列举本篇用到的分类(内连接,外连接,交叉连接)和连接方法(如下): A)内连接:join,inner join B)外连接:left join,left outer join,right join,right out...
    99+
    2014-07-14
    Mysql 多表连接查询 inner join outer join 的使用
  • mysql中left join关键字的使用
    本篇文章给大家分享的是有关mysql中left join关键字的使用,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。left join关键字LE...
    99+
    2022-10-18
  • 一文详解MySQL—Join的使用优化
    目录mysql JOIN类型MySQL JOIN 算法Nested-Loop Join 算法执行流程工作原理时间复杂度分析block Nested-Loop Join 算法执行流程工作原理时间复杂度分析Hash Join...
    99+
    2023-04-21
    MySQL Join使用 MySQL Join优化 MySQL Join
  • mysql left join快速转inner join的过程
    在日常优化过程中,发现一个怪事情,同一个SQL出现两个完全不一样执行计划,left join 连驱动表都可以变成不一样。 对于left join,如果where条件里有被关联表过滤,left join有...
    99+
    2022-05-15
    mysql left join inner join mysql left join转 inner join
  • MySQL中JOIN怎么用
    小编给大家分享一下MySQL中JOIN怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!简介A的独有+AB的公有B的独有+AB的公有AB的公有A的独有B的独有A...
    99+
    2023-06-29
  • 一文详解MySQL Join使用原理
    目录Join的类型Join原理Simpe Nested-Loop JoinIndex Nested-Loop JoinBlock Nested-Loop JoinJoin优化Join...
    99+
    2023-05-17
    MySQL Join原理 MySQL Join
  • MySQL优化器hash join怎么使用
    今天小编给大家分享一下MySQL优化器hash join怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收...
    99+
    2022-10-19
  • 一文详解MySQL Join使用原理
    目录Join的类型Join原理Simpe Nested-Loop JoinIndex Nested-Loop Joinblock Nested-Loop JoinJoin优化Join的类型 left join,以左表为驱...
    99+
    2023-04-25
    MySQL Join原理 MySQL Join
  • MySQL的join buffer原理
    一、MySQL的join buffer 在MySQL对于join操作的处理过程中,join buffer是一个重要的概念,也是MySQL对于table join的一个重要的优化手段。虽然这个概念实现并不复杂,但是这...
    99+
    2022-05-19
    MySQL join buffer
  • MySQL的 join功能有什么用
    小编给大家分享一下MySQL的 join功能有什么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!关于MySQL 的 join,...
    99+
    2022-10-18
  • mysql中join的作用是什么
    这篇文章主要介绍“mysql中join的作用是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“mysql中join的作用是什么”文章能帮助大家解决问题。 ...
    99+
    2022-11-30
    mysql join
  • 干涉MySQL优化器使用hash join的方法
    GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源。GreatSQL是mysql的国产分支版本,使用上与MySQL一致。 前言 数据库的优化器相当于人类的大脑,大部分时候都能做出正确的决策,制定正...
    99+
    2022-09-13
  • 干涉MySQL优化器使用hash join的方法
    GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源。GreatSQL是MySQL的国产分支版本,使用上与MySQL一致。 前言 数据库的优化器相当于人类的大脑...
    99+
    2022-11-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作