什么是内连接、外连接?MySQL支持哪些外连接?_oracle内连接和外连接的区别

什么是内连接、外连接?MySQL支持哪些外连接?_oracle内连接和外连接的区别图片与最后一部分来自:https://blog.csdn.net/plg17/article/details/78758593已有如下表rollcall数据表course数据表内链接innerjoin语句:select表1查询的字段,表2查询的字段from表1innerjoin表2on条件;如:mysql>selecta.*,b.*from…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

图片与最后一部分来自:https://blog.csdn.net/plg17/article/details/78758593

已有如下表

rollcall 数据表
在这里插入图片描述
course 数据表
在这里插入图片描述

内链接 inner join

语句:
select 表1查询的字段,表2查询的字段 from 表1 inner join 表2 on 条件;
如:

mysql> select a.*,b.* from course as a inner join rollcall as b on a.course_id=b.course_id;
+-----------+-------------+------+---------+-----------+-----------+----+-----------+------------+--------------+--------------+---------+
| course_id | course_name | time | teacher | classroom | t_command | db | course_id | student_id | student_name | teacher_name | command |
+-----------+-------------+------+---------+-----------+-----------+----+-----------+------------+--------------+--------------+---------+
|         1 | 1234        | 123  | 123     | 123       |       123 |  2 |         1 | 1501010096 | 于宗云       | 123          |     123 |
+-----------+-------------+------+---------+-----------+-----------+----+-----------+------------+--------------+--------------+---------+
1 row in set (0.07 sec)

内连接会返回两表的交集:
在这里插入图片描述

外连接 分为左外连接,右外连接

左外连接 left join

语句:
select 表1查询的字段,表2查询的字段 from 表1 left join 表2 on 条件; // 只改变了连接的语句,其他写法相同
如:

mysql> select a.*,b.* from course as a left join rollcall as b on a.course_id=b.course_id;
+-----------+-------------+------+---------+-----------+-----------+------+-----------+------------+--------------+--------------+---------+
| course_id | course_name | time | teacher | classroom | t_command | db   | course_id | student_id | student_name | teacher_name | command |
+-----------+-------------+------+---------+-----------+-----------+------+-----------+------------+--------------+--------------+---------+
|         1 | 1234        | 123  | 123     | 123       |       123 |    2 |         1 | 1501010096 | 于宗云       | 123          |     123 |
|         2 | 123         | 123  | 123     | 123       |       123 | NULL |      NULL | NULL       | NULL         | NULL         |    NULL |
+-----------+-------------+------+---------+-----------+-----------+------+-----------+------------+--------------+--------------+---------+

说明:
left join 是left outer join的简写,它的全称是左外连接,是外连接中的一种。
左(外)连接,左表(a_table)的记录将会全部表示出来,而右表(b_table)只会显示符合搜索条件的记录。右表记录不足的地方均为NULL。
在这里插入图片描述

右外连接 right join

语句:
select 表1查询的字段,表2查询的字段 from 表1 right join 表2 on 条件; // 只改变了连接的语句,其他写法相同
如:

mysql> select a.*,b.* from course as a right join rollcall as b on a.course_id=b.course_id;
+-----------+-------------+------+---------+-----------+-----------+----+-----------+------------+--------------+--------------+---------+
| course_id | course_name | time | teacher | classroom | t_command | db | course_id | student_id | student_name | teacher_name | command |
+-----------+-------------+------+---------+-----------+-----------+----+-----------+------------+--------------+--------------+---------+
|         1 | 1234        | 123  | 123     | 123       |       123 |  2 |         1 | 1501010096 | 于宗云       | 123          |     123 |
+-----------+-------------+------+---------+-----------+-----------+----+-----------+------------+--------------+--------------+---------+
1 row in set (0.00 sec)

说明:
right join是right outer join的简写,它的全称是右外连接,是外连接中的一种。
与左(外)连接相反,右(外)连接,左表(a_table)只会显示符合搜索条件的记录,而右表(b_table)的记录将会全部表示出来。左表记录不足的地方均为NULL。
在这里插入图片描述

全接连

MySQL 已经没有全连接了,有的教程上还写着 full join 但是实现不了,不过可以换一种方式来查询。
语句:
(SELECT * from a left JOIN b on a.name=b.id) UNION (SELECT * from a RIGHT JOIN b on a.name=b.id );

mysql> (select a.*,b.* from course as a right join rollcall as b on a.course_id=b.course_id) UNION ( select a.*,b.* from course as a LEFT join rollcall as b on a.course_id=b.course_id);
+-----------+-------------+------+---------+-----------+-----------+------+-----------+------------+--------------+--------------+---------+
| course_id | course_name | time | teacher | classroom | t_command | db   | course_id | student_id | student_name | teacher_name | command |
+-----------+-------------+------+---------+-----------+-----------+------+-----------+------------+--------------+--------------+---------+
|         1 | 1234        | 123  | 123     | 123       |       123 |    2 |         1 | 1501010096 | 于宗云       | 123          |     123 |
|      NULL | NULL        | NULL | NULL    | NULL      |      NULL |    3 |      NULL | NULL       | NULL         | NULL         |    NULL |
|         2 | 123         | 123  | 123     | 123       |       123 | NULL |      NULL | NULL       | NULL         | NULL         |    NULL |
|         3 | 123         | 123  | 123     | 123       |       123 | NULL |      NULL | NULL       | NULL         | NULL         |    NULL |
+-----------+-------------+------+---------+-----------+-----------+------+-----------+------------+--------------+--------------+---------+
4 rows in set (0.00 sec)

补充,MySQL如何执行关联查询

**MySQL认为任何一个查询都是一次“关联”,**并不仅仅是一个查询需要到两个表匹配才叫关联,所以在MySQL中,每一个查询,每一个片段(包括子查询,甚至基于单表查询)都可以是一次关联。
当前MySQL关联执行的策略很简单:**MySQL对任何关联都执行嵌套循环关联操作,即MySQL先在一个表中循环取出单条数据,然后在嵌套循环到下一个表中寻找匹配的行,依次下去,直到找到所有表中匹配的行为止。**然后根据各个表匹配的行,返回查询中需要的各个列。请看下面的例子中的简单的查询:

查询语句:select tbl1.col1, tbl2.col2 from tbl1 inner join tbl2 using(col3) where tbl1.col1 in (5, 6);
假设MySQL按照查询中的表顺序进行关联操作,我们则可以用下面的伪代码表示MySQL将如何完成这个查询:

outer_iter = iterator over tbl1 where col1 in (5, 6)
outer_row = outer_iter.next
while outer_row
    inner_iter = iterator over tbl2 where col3 = outer_row.col3
    inner_row = inner_iter.next
    while inner_row
        output [ outer_row.col1, inner_row.col2]
        inner_row = inner_iter.next
    end
    outer_row = outer_iter.next
end

上面的执行计划对于单表查询和多表关联查询都适用,如果是一个单表查询,那么只需要上面外层的基本操作。对于外连接,上面的执行过程仍然适用。例如,我们将上面的查询语句修改如下:
select tbl1.col1, tbl2.col2 from tbl1 left outer join tbl2 using(col3) where tbl1.col1 in (5, 6);
那么,对应的伪代码如下:

outer_iter = iterator over tbl1 where col1 in (5, 6)
outer_row = outer_iter.next
while outer_row
    inner_iter = iterator over tbl2 where col3 = outer_row.col3
    inner_row = inner_iter.next
    if inner_row
        while inner_row
            output [ outer_row.col1, inner_row.col2]
            inner_row = inner_iter.next
        end
    else
        output [ outer_row.col1, null]
    end
        outer_row = outer_iter.next
end
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/179261.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • FindWindow和FindWindowEx

    FindWindow和FindWindowEx函数型:HWNDFindWindow(LPCTSTRIpClassName,LPCTSTRIpWindowName);IpClassName:指向一个指定了类名的空结束字符串或一个标识类名字符串的成员的指针。如果该参数为一个成员,则它必须为前次调用theGlobaIAddAtom函数产生的全局成员。该成员为16位,必须位于lpClassName的低16位,高位必须为0。如果为NULL,

    2022年5月31日
    39
  • 网络编程中的 SIGPIPE 信号[通俗易懂]

    网络编程中的 SIGPIPE 信号[通俗易懂]处理SIGPIPE在网络编程中经常会遇到SIGPIPE信号,默认情况下这个信号会终止整个进程,当然你并不想让进程被SIGPIPE信号杀死。我们不禁会这样思考:在什么场景下会产生SIGPIPE信号

    2022年7月1日
    35
  • 一个域名最多能对应几个IP地址?,一个IP地址可以绑定几个域名?

    一个域名最多能对应几个IP地址?,一个IP地址可以绑定几个域名?

    2021年9月20日
    216
  • trylock 用法_Java lock

    trylock 用法_Java lock在并发编程中,为了避免多线程同时读写共享资源,我们需要互斥。Go标准库提供了互斥锁sync.Mutex,通过加锁Lock()方法和解锁Unlock()方法达到对共享资源的并发控制。在之前的设计中,当锁被占有,其他goroutine尝试获取锁时会被阻塞。这种方式当然是合理的,但是在某些情况下,或许我们希望在获取锁失败时,并不想停止执行,而是可以进入其他的逻…

    2022年10月10日
    6
  • java创建文件 权限_JAVA创建文件后权限不足的问题,无法设置权限的问题「建议收藏」

    java创建文件 权限_JAVA创建文件后权限不足的问题,无法设置权限的问题「建议收藏」JAVA创建文件后权限不足的问题,无法设置权限的问题凯哥java凯哥java前言:在工作中,项目使用到文件上传,这个功能是很常见的吧。今天,凯哥修改自己的公众号的时候,遇到了一个问题:那就是上传后的文件访问不到,使用浏览器访问不到了。怎么办呢?经过多次查询,发现竟然是因为tomcat的配置原因!正文:最近在Linux系统中通过tomcat部署项目后,由于程序有上传文件功能。而上传后的却无法查看…

    2022年6月18日
    69
  • 关联关系和依赖关系的区别[建议收藏]

    关联关系:A类实例化的时候需要B类的对象引用或指针作为参数依赖关系:A类的某个方法使用B类,可能是方法的参数是B类或在方法中获得了一个B类的实例某个类以成员变量的形式出现在另一个类中,二者是关联关

    2021年12月18日
    52

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号