关于多表查询sql常用的连接语句:左外连接、右外连接、内连接

2023-12-06 12:39

本文主要是介绍关于多表查询sql常用的连接语句:左外连接、右外连接、内连接,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1)内联接:

   内联接使用比较运算符(使用像 =  或 <> 之类的比较运算符)根据每个表共有的列的值匹配两个表中的行,根据这两张表中相同列的条件,得出其      交集。例如:  检索 students和courses表中学生标识号相同的所有行。   

     有两种,显式的和隐式的,返回连接表中符合连接条件和查询条件的数据行(链接表就是数据库在做查询形成的中间表)。

      隐式的内连接:

 没有INNER JOIN,形成的中间表为两个表的笛卡尔积。   

[sql]  view plain copy
  1. SELECT O.ID,O.ORDER_NUMBER,C.ID,C.NAME  
  2. FROM CUSTOMERS C,ORDERS O  
  3. WHERE C.ID=O.CUSTOMER_ID;  
     显示的内连接:

一般称为内连接,有INNER JOIN,形成的中间表为两个表经过ON条件过滤后的笛卡尔积。

[sql]  view plain copy
  1. SELECT O.ID,O.ORDER_NUMBER,C.ID,C.NAME  
  2. FROM CUSTOMERS C INNER JOIN ORDERS O ON C.ID=O.CUSTOMER_ID;  


  但是,这两个查询的结果是一样的。

2)左向外联:

      是用的是LEFT  JOIN或LEFT OUTER JOIN     连接语句。

      根据两张表的关系(外键关联),笛卡尔过滤,也就是求出两张表的交集, 如果交集中,左边表的行, 在右边表中没有匹配,则该条记录左边表有数据, 右边表所有的字段都为null。

       左外连接时,写where语句的独立查询条件:  规则, on后面写连接条件, where后写查询条件  

[sql]  view plain copy
  1. SELECT O.ID,O.ORDER_NUMBER,O.CUSTOMER_ID,C.ID,C.NAME  
  2. FROM ORDERS O LEFT OUTER JOIN CUSTOMERS C ON C.ID=O.CUSTOMER_ID  
  3. WHERE O.ORDER_NUMBER<>'MIKE_ORDER001';  


3)右外连接:

      RIGHT  JOIN 或 RIGHT  OUTER  JOIN     连接语句

       和左外连接是相反的,查出的两张表的交集, 如果这条记录,右边表有数据,左边表没有, 则把左边表的字段都设置为null。


 案例:

[sql]  view plain copy
  1. a表     id   name     b表     id   job   parent_id     
  2.             1   张3                   1     23     1     
  3.             2   李四                 2     34     2     
  4.             3   王武                 3     34     4         
  5. a.id同parent_id   存在关系     

  内连接查询:

[sql]  view plain copy
  1. select   a.*,b.*   from   a   inner   join   b     on   a.id=b.parent_id        
  2. 结果是       
  3. 1   张3                   1     23     1     
  4. 2   李四                  2     34     2     

左连接   :

[sql]  view plain copy
  1. select   a.*,b.*   from   a   left   join   b     on   a.id=b.parent_id        
  2. 结果是       
  3. 1   张3                   1     23     1     
  4. 2   李四                  2     34     2     
  5. 3   王武                  null     
 右连接    :

[sql]  view plain copy
  1. select   a.*,b.*   from   a   right   join   b     on   a.id=b.parent_id         
  2. 结果是       
  3. 1   张3                   1     23     1     
  4. 2   李四                  2     34     2     
  5. null                       3     34     4    



对于SQL查询的基本原理:

1)单表查询:根据WHERE条件过滤表中的记录,然后根据SELECT的选择列选择相应的列进行返回最终结果。

 2)两表连接查询: 在on后面写连接条件, 在where后面写过滤的查询条件,然后再根据SELECT指定的列返回查询结果。

3)多表连接查询:先对第一个和第二个表按照两表连接做查询,然后用查询结果和第三个表做连接查询,以此类推,直到所有的表都连接上为止,最终形成一个中间的结果表,然后根据WHERE条件过滤中间表的记录,并根据SELECT指定的列返回查询结果。


关于on条件和where条件的区别:

ON条件:是过滤两个链接表笛卡尔积形成中间表的约束条件。

WHERE条件:ON只进行连接操作,WHERE只过滤中间表的记录。


对于连接类型的选择:  在实际运用中如果连接类型选择不当, 不但出现效率低并且可能还会出现逻辑的错误

1、 查两表关联列相等的数据用内连接

2、 Col_L是Col_R的子集时用右外连接。(左边表是右边表的子集,用右外)

3、 Col_R是Col_L的子集时用左外连接。(右边表是左边表的子集, 用左外)

4、 求差操作的时候用联合查询。

并且,多个表查询的时候,这些不同的连接类型可以写到一块

例如:

[sql]  view plain copy
  1. SELECT T1.C1,T2.CX,T3.CY  
  2. FROM TAB1 T1  
  3.        INNER JOIN TAB2 T2 ON (T1.C1=T2.C2)  
  4.        INNER JOIN TAB3 T3 ON (T1.C1=T2.C3)  
  5.        LEFT OUTER JOIN TAB4 ON(T2.C2=T3.C3);  
  6. WHERE T1.X >T3.Y;  

这篇关于关于多表查询sql常用的连接语句:左外连接、右外连接、内连接的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/461851

相关文章

浅谈mysql的not exists走不走索引

《浅谈mysql的notexists走不走索引》在MySQL中,​NOTEXISTS子句是否使用索引取决于子查询中关联字段是否建立了合适的索引,下面就来介绍一下mysql的notexists走不走索... 在mysql中,​NOT EXISTS子句是否使用索引取决于子查询中关联字段是否建立了合适的索引。以下

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys

SQL中如何添加数据(常见方法及示例)

《SQL中如何添加数据(常见方法及示例)》SQL全称为StructuredQueryLanguage,是一种用于管理关系数据库的标准编程语言,下面给大家介绍SQL中如何添加数据,感兴趣的朋友一起看看吧... 目录在mysql中,有多种方法可以添加数据。以下是一些常见的方法及其示例。1. 使用INSERT I

Qt使用QSqlDatabase连接MySQL实现增删改查功能

《Qt使用QSqlDatabase连接MySQL实现增删改查功能》这篇文章主要为大家详细介绍了Qt如何使用QSqlDatabase连接MySQL实现增删改查功能,文中的示例代码讲解详细,感兴趣的小伙伴... 目录一、创建数据表二、连接mysql数据库三、封装成一个完整的轻量级 ORM 风格类3.1 表结构

Spring Boot中WebSocket常用使用方法详解

《SpringBoot中WebSocket常用使用方法详解》本文从WebSocket的基础概念出发,详细介绍了SpringBoot集成WebSocket的步骤,并重点讲解了常用的使用方法,包括简单消... 目录一、WebSocket基础概念1.1 什么是WebSocket1.2 WebSocket与HTTP

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字

Mysql实现范围分区表(新增、删除、重组、查看)

《Mysql实现范围分区表(新增、删除、重组、查看)》MySQL分区表的四种类型(范围、哈希、列表、键值),主要介绍了范围分区的创建、查询、添加、删除及重组织操作,具有一定的参考价值,感兴趣的可以了解... 目录一、mysql分区表分类二、范围分区(Range Partitioning1、新建分区表:2、分

MySQL 定时新增分区的实现示例

《MySQL定时新增分区的实现示例》本文主要介绍了通过存储过程和定时任务实现MySQL分区的自动创建,解决大数据量下手动维护的繁琐问题,具有一定的参考价值,感兴趣的可以了解一下... mysql创建好分区之后,有时候会需要自动创建分区。比如,一些表数据量非常大,有些数据是热点数据,按照日期分区MululbU

SQL Server配置管理器无法打开的四种解决方法

《SQLServer配置管理器无法打开的四种解决方法》本文总结了SQLServer配置管理器无法打开的四种解决方法,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录方法一:桌面图标进入方法二:运行窗口进入检查版本号对照表php方法三:查找文件路径方法四:检查 S

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语