关于多表查询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

相关文章

Python正则表达式语法及re模块中的常用函数详解

《Python正则表达式语法及re模块中的常用函数详解》这篇文章主要给大家介绍了关于Python正则表达式语法及re模块中常用函数的相关资料,正则表达式是一种强大的字符串处理工具,可以用于匹配、切分、... 目录概念、作用和步骤语法re模块中的常用函数总结 概念、作用和步骤概念: 本身也是一个字符串,其中

SQL中redo log 刷⼊磁盘的常见方法

《SQL中redolog刷⼊磁盘的常见方法》本文主要介绍了SQL中redolog刷⼊磁盘的常见方法,将redolog刷入磁盘的方法确保了数据的持久性和一致性,下面就来具体介绍一下,感兴趣的可以了解... 目录Redo Log 刷入磁盘的方法Redo Log 刷入磁盘的过程代码示例(伪代码)在数据库系统中,r

mysql中的group by高级用法

《mysql中的groupby高级用法》MySQL中的GROUPBY是数据聚合分析的核心功能,主要用于将结果集按指定列分组,并结合聚合函数进行统计计算,下面给大家介绍mysql中的groupby用法... 目录一、基本语法与核心功能二、基础用法示例1. 单列分组统计2. 多列组合分组3. 与WHERE结合使

usb接口驱动异常问题常用解决方案

《usb接口驱动异常问题常用解决方案》当遇到USB接口驱动异常时,可以通过多种方法来解决,其中主要就包括重装USB控制器、禁用USB选择性暂停设置、更新或安装新的主板驱动等... usb接口驱动异常怎么办,USB接口驱动异常是常见问题,通常由驱动损坏、系统更新冲突、硬件故障或电源管理设置导致。以下是常用解决

Mysql用户授权(GRANT)语法及示例解读

《Mysql用户授权(GRANT)语法及示例解读》:本文主要介绍Mysql用户授权(GRANT)语法及示例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql用户授权(GRANT)语法授予用户权限语法GRANT语句中的<权限类型>的使用WITH GRANT

Mysql如何解决死锁问题

《Mysql如何解决死锁问题》:本文主要介绍Mysql如何解决死锁问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录【一】mysql中锁分类和加锁情况【1】按锁的粒度分类全局锁表级锁行级锁【2】按锁的模式分类【二】加锁方式的影响因素【三】Mysql的死锁情况【1

SQL BETWEEN 的常见用法小结

《SQLBETWEEN的常见用法小结》BETWEEN操作符是SQL中非常有用的工具,它允许你快速选取某个范围内的值,本文给大家介绍SQLBETWEEN的常见用法,感兴趣的朋友一起看看吧... 在SQL中,BETWEEN是一个操作符,用于选取介于两个值之间的数据。它包含这两个边界值。BETWEEN操作符常用

MySQL索引的优化之LIKE模糊查询功能实现

《MySQL索引的优化之LIKE模糊查询功能实现》:本文主要介绍MySQL索引的优化之LIKE模糊查询功能实现,本文通过示例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一、前缀匹配优化二、后缀匹配优化三、中间匹配优化四、覆盖索引优化五、减少查询范围六、避免通配符开头七、使用外部搜索引擎八、分

MySql match against工具详细用法

《MySqlmatchagainst工具详细用法》在MySQL中,MATCH……AGAINST是全文索引(Full-Textindex)的查询语法,它允许你对文本进行高效的全文搜素,支持自然语言搜... 目录一、全文索引的基本概念二、创建全文索引三、自然语言搜索四、布尔搜索五、相关性排序六、全文索引的限制七

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指