文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

如何正确的使用mysql-joins方法

2023-06-06 17:01

关注

今天就跟大家聊聊有关如何正确的使用mysql-joins方法,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

假设有两个表,Table_A和Table_B。这两个表中的数据如下所示:

TABLE_A| TABLE_B PK Value      |   PK Value---- ----------    |   ---- ---------- 1 FOX     |   1 TROT 2 COP     |   2 CAR 3 TAXI     |   3 CAB 6 WASHINGTON    |   6 MONUMENT 7 DELL     |   7 PC 5 ARIZONA    |   8 MICROSOFT 4 LINCOLN    |   9 APPLE 10 LUCENT     |   11 SCOTCH

Join 语法:

join_table: table_reference JOIN table_factor [join_condition]//内连接 | table_reference {LEFT|RIGHT|FULL} [OUTER] JOIN table_reference join_condition//外连接 | table_reference LEFT SEMI JOIN table_reference join_condition//左半连接 | table_reference CROSS JOIN table_reference [join_condition] (as of Hive 0.10)table_reference: table_factor//表 | join_table//join语句table_factor: tbl_name [alias]//表名[别名] | table_subquery alias//子查寻[别名] | ( table_references )//带空号的table_referencejoin_condition: ON expression//on开头的条件语句

1、Inner JOIN: (内连接)

如何正确的使用mysql-joins方法

这是最简单、最容易理解的连接,也是最常见的连接。此查询将返回左表(表A)中具有右表(表B)中匹配记录的所有记录。此连接写成如下:

SELECT <select_list> FROM Table_A AINNER JOIN Table_B BON A.Key = B.Key
-- Inner JOINSELECT A.PK AS A_PK, A.Value AS A_Value,  B.Value AS B_Value, B.PK AS B_PKFROM Table_A AINNER JOIN Table_B BON A.PK = B.PKA_PK A_Value B_Value B_PK---- ---------- ---------- ---- 1 FOX  TROT   1 2 COP  CAR   2 3 TAXI  CAB   3 6 WASHINGTON MONUMENT  6 7 DELL  PC   7(5 row(s) affected)

2、Left JOIN: (左连接)

如何正确的使用mysql-joins方法

此查询将返回左表(表A)中的所有记录,而不管这些记录是否与右表(表B)中的任何记录匹配。它还将从正确的表中返回任何匹配的记录。此连接写成如下:

SELECT <select_list>FROM Table_A ALEFT JOIN Table_B BON A.Key = B.Key
-- Left JOINSELECT A.PK AS A_PK, A.Value AS A_Value,B.Value AS B_Value, B.PK AS B_PKFROM Table_A ALEFT JOIN Table_B BON A.PK = B.PKA_PK A_Value B_Value B_PK---- ---------- ---------- ---- 1 FOX  TROT   1 2 COP  CAR   2 3 TAXI  CAB   3 4 LINCOLN NULL  NULL 5 ARIZONA NULL  NULL 6 WASHINGTON MONUMENT  6 7 DELL  PC   7 10 LUCENT  NULL  NULL(8 row(s) affected)

3、Left Excluding JOIN: (左连接排除内连接结果)

此查询将返回左表(表A)中与右表(表B)中的任何记录都不匹配的所有记录。此连接写成如下:

如何正确的使用mysql-joins方法

SELECT <select_list> FROM Table_A ALEFT JOIN Table_B BON A.Key = B.KeyWHERE B.Key IS NULL
-- Left Excluding JOINSELECT A.PK AS A_PK, A.Value AS A_Value,B.Value AS B_Value, B.PK AS B_PKFROM Table_A ALEFT JOIN Table_B BON A.PK = B.PKWHERE B.PK IS NULLA_PK A_Value B_Value B_PK---- ---------- ---------- ---- 4 LINCOLN NULL  NULL 5 ARIZONA NULL  NULL 10 LUCENT  NULL  NULL(3 row(s) affected)

4、Right JOIN: (右连接)

如何正确的使用mysql-joins方法

此查询将返回右表(表B)中的所有记录,而不管这些记录中是否有任何记录与左表(表A)中的记录相匹配。它还将返回左表中的任何匹配记录。此连接写成如下:

SELECT <select_list>FROM Table_A ARIGHT JOIN Table_B BON A.Key = B.Key
-- Right JOINSELECT A.PK AS A_PK, A.Value AS A_Value,B.Value AS B_Value, B.PK AS B_PKFROM Table_A ARIGHT JOIN Table_B BON A.PK = B.PKA_PK A_Value B_Value B_PK---- ---------- ---------- ---- 1 FOX  TROT   1 2 COP  CAR   2 3 TAXI  CAB   3 6 WASHINGTON MONUMENT  6 7 DELL  PC   7NULL NULL  MICROSOFT  8NULL NULL  APPLE   9NULL NULL  SCOTCH  11(8 row(s) affected)

5、Right Excluding JOIN: (右连接排除内连接结果)

如何正确的使用mysql-joins方法

此查询将返回右表(表B)中与左表(表A)中的任何记录都不匹配的所有记录。此连接写成如下:

SELECT <select_list>FROM Table_A ARIGHT JOIN Table_B BON A.Key = B.KeyWHERE A.Key IS NULL
-- Right Excluding JOINSELECT A.PK AS A_PK, A.Value AS A_Value,B.Value AS B_Value, B.PK AS B_PKFROM Table_A ARIGHT JOIN Table_B BON A.PK = B.PKWHERE A.PK IS NULLA_PK A_Value B_Value B_PK---- ---------- ---------- ----NULL NULL  MICROSOFT  8NULL NULL  APPLE   9NULL NULL  SCOTCH  11(3 row(s) affected)

6、Outer JOIN: (外连接)

如何正确的使用mysql-joins方法

此联接也可以称为完全外联接或完全联接。此查询将返回两个表中的所有记录,连接左表(表A)中与右表(表B)中的记录相匹配的记录。此连接写成如下:

SELECT <select_list>FROM Table_A AFULL OUTER JOIN Table_B BON A.Key = B.Key
-- Outer JOINSELECT A.PK AS A_PK, A.Value AS A_Value,B.Value AS B_Value, B.PK AS B_PKFROM Table_A AFULL OUTER JOIN Table_B BON A.PK = B.PKA_PK A_Value B_Value B_PK---- ---------- ---------- ---- 1 FOX  TROT   1 2 COP  CAR   2 3 TAXI  CAB   3 6 WASHINGTON MONUMENT  6 7 DELL  PC   7NULL NULL  MICROSOFT  8NULL NULL  APPLE   9NULL NULL  SCOTCH  11 5 ARIZONA NULL  NULL 4 LINCOLN NULL  NULL 10 LUCENT  NULL  NULL(11 row(s) affected)

7、Outer Excluding JOIN: (外连接排除内连接结果)

如何正确的使用mysql-joins方法

此查询将返回左表(表A)中的所有记录和右表(表B)中不匹配的所有记录。我还不需要使用这种类型的联接,但所有其他类型的联接我都相当频繁地使用。此连接写成如下:

SELECT <select_list>FROM Table_A AFULL OUTER JOIN Table_B BON A.Key = B.KeyWHERE A.Key IS NULL OR B.Key IS NULL
-- Outer Excluding JOINSELECT A.PK AS A_PK, A.Value AS A_Value,B.Value AS B_Value, B.PK AS B_PKFROM Table_A AFULL OUTER JOIN Table_B BON A.PK = B.PKWHERE A.PK IS NULLOR B.PK IS NULLA_PK A_Value B_Value B_PK---- ---------- ---------- ----NULL NULL  MICROSOFT  8NULL NULL  APPLE   9NULL NULL  SCOTCH  11 5 ARIZONA NULL  NULL 4 LINCOLN NULL  NULL 10 LUCENT  NULL  NULL(6 row(s) affected)

注意,在外部联接上,首先返回内部连接记录,然后返回右连接记录,最后返回左连接记录(至少,我的Microsoft SQL Server就是这样做的;当然,这不需要使用任何ORDERBY语句)。您可以访问维基百科文章以获得更多信息(但是,条目不是图形化的)。我还创建了一个备忘单,您可以在需要时打印出来。如果您右键单击下面的图像并选择“将目标保存为.”,您将下载完整大小的图像。

如何正确的使用mysql-joins方法

看完上述内容,你们对如何正确的使用mysql-joins方法有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注编程网行业资讯频道,感谢大家的支持。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     801人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     348人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     311人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     432人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     220人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯