`

SQL中内连接和外连接

sql 
阅读更多
SQL中内连接和外连接

如表  
  -------------------------------------------------  
  table1 | table2 |  
  -------------------------------------------------  
  id name |id score |  
  1 lee |1 90 |  
  2 zhang |2 100 |  
  4 wang |3 70 |  
  -------------------------------------------------  
   
  以下均在查询分析器中执行  
   
  一、外连接  
  1.概念:包括左向外联接、右向外联接或完整外部联接  
   
  2.左连接:left   join   或   left   outer   join  
  (1)左向外联接的结果集包括   LEFT   OUTER   子句中指定的左表的所有行,而不仅仅是联接列所匹配的行。如果左表的某行在右表中没有匹配行,则在相关联的结果集行中右表的所有选择列表列均为空值(null)。  
  (2)sql语句  
  select   *   from   table1   left   join   table2   on   table1.id=table2.id  
  -------------结果-------------  
  id name id score  
  ------------------------------  
  1 lee 1 90  
  2 zhang 2 100  
  4 wang NULL NULL  
  ------------------------------  
  注释:包含table1的所有子句,根据指定条件返回table2相应的字段,不符合的以null显示  
   
  3.右连接:right   join   或   right   outer   join  
  (1)右向外联接是左向外联接的反向联接。将返回右表的所有行。如果右表的某行在左表中没有匹配行,则将为左表返回空值。  
  (2)sql语句  
  select   *   from   table1   right   join   table2   on   table1.id=table2.id  
  -------------结果-------------  
  id name id score  
  ------------------------------  
  1 lee 1 90  
  2 zhang 2 100  
  NULL NULL 3 70  
  ------------------------------  
  注释:包含table2的所有子句,根据指定条件返回table1相应的字段,不符合的以null显示  
   
  4.完整外部联接:full   join   或   full   outer   join    
  (1)完整外部联接返回左表和右表中的所有行。当某行在另一个表中没有匹配行时,则另一个表的选择列表列包含空值。如果表之间有匹配行,则整个结果集行包含基表的数据值。  
  (2)sql语句  
  select   *   from   table1   full   join   table2   on   table1.id=table2.id  
  -------------结果-------------  
  id name id score  
  ------------------------------  
  1 lee 1 90  
  2 zhang 2 100  
  4 wang NULL NULL  
  NULL NULL 3 70  
  ------------------------------  
  注释:返回左右连接的union(见上左、右连接)  
   
  二、内连接  
  1.概念:内联接是用比较运算符比较要联接列的值的联接  
   
  2.内连接:join   或   inner   join    
   
  3.sql语句  
  select   *   from   table1   join   table2   on   table1.id=table2.id  
  -------------结果-------------  
  id name id score  
  ------------------------------  
  1 lee 1 90  
  2 zhang 2 100  
  ------------------------------  
  注释:只返回符合条件的table1和table2的列  
   
  4.等价(与下列执行效果相同)  
  A:select   a.*,b.*   from   table1   a,table2   b   where   a.id=b.id  
  B:select   *   from   table1   cross   join   table2   where   table1.id=table2.id     (注:cross   join后加条件只能用where,不能用on)  
   
  三、交叉连接(完全)  
   
  1.概念:没有   WHERE   子句的交叉联接将产生联接所涉及的表的笛卡尔积。第一个表的行数乘以第二个表的行数等于笛卡尔积结果集的大小。(table1和table2交叉连接产生3*3=9条记录)  
   
  2.交叉连接:cross   join   (不带条件where...)  
   
  3.sql语句  
  select   *   from   table1   cross   join   table2  
  -------------结果-------------  
  id name id score  
  ------------------------------  
  1 lee 1 90  
  2 zhang 1 90  
  4 wang 1 90  
  1 lee 2 100  
  2 zhang 2 100  
  4 wang 2 100  
  1 lee 3 70  
  2 zhang 3 70  
  4 wang 3 70  
  ------------------------------  
  注释:返回3*3=9条记录,即笛卡尔积  
   
  4.等价(与下列执行效果相同)  
  A:select   *   from   table1,table2  
分享到:
评论

相关推荐

    sql内连接和外连接

    ### SQL内连接与外连接详解 #### 一、SQL内连接(INNER JOIN) **定义**: 内连接(INNER JOIN)是一种最常用的连接方式,它仅返回两个数据集合中具有匹配关系的那些行。具体来说,它会从位于两个互相交叉的数据...

    SQL优化使用内连接代替外连接

    SQL优化--使用内连接(inner join)代替外连接(left join,right join)

    SQL关于内连接,外连接(左右连接)等的总结

    当我们需要从多个表中获取数据并合并它们时,SQL提供了不同类型的连接操作,包括内连接、外连接(左连接和右连接)。以下是这些连接方式的详细说明。 **内连接(Inner Join)** 内连接返回两个表中存在匹配的记录。...

    sql左外连接、右外连接、内连接、全外连接的区别

    根据连接的方向和目的,可以分为几种不同的类型:左外连接(LEFT JOIN)、右外连接(RIGHT JOIN)、内连接(INNER JOIN)以及全外连接(FULL JOIN)。下面将详细介绍这四种连接类型,并通过示例来解释它们之间的区别...

    SQL 左外连接,右外连接,全连接,内连接 四种连接的差异.doc

    SQL 连接的四种类型:左外连接、右外连接、全连接、内连接 在 SQL 中,连接(JOIN)是一种非常重要的概念,它允许我们从多个表中检索数据。连接可以分为四种类型:左外连接、右外连接、全连接和内连接。每种连接都...

    SQL子查询、内连接和外连接查询

    在SQL中,子查询、内连接和外连接是进行复杂数据检索的关键工具。这些概念的理解和熟练应用对于数据库管理与数据分析至关重要。 **子查询** 是一个嵌套在其他SQL语句中的查询,它首先执行并返回结果,这个结果再...

    SQL_左外连接_右外连接_全连接_内连接

    以下是关于SQL连接的不同类型及其详细解释: 1. **内连接(Inner Join)**: 内连接返回两个表中存在匹配的行。这通常通过在`FROM`子句中指定`JOIN`或`INNER JOIN`来实现,比较两个表中的共同列,只返回那些列值...

    SQL左外连接,右外连接,全连接,内连接四种连接的差异[参照].pdf

    SQL中的连接操作是数据库查询的...综上所述,SQL连接操作提供了灵活的数据集成方法,根据需要选择合适的连接类型对于数据查询至关重要。理解这些连接的差异可以帮助你编写更精确、高效的查询,以满足特定的业务需求。

    SQL多表进行内连接和外连接查询

    通常在项目中对表的查询都是关联多张表,多表查询就涉及到sql的内连接、外连接和自连接查询。本篇文章将简单的介绍这些sql连接的使用,希望对大家有所帮助。

    SQL基本SELECT查询语句_内外连接

    SQL基本SELECT查询语句_内外连接

    SQL 内连接,外连接

    SQL 内连接,外连接:假设一堆男女在教堂,有夫妇有单身的,假设男为左表,女为右表......

    SqlServer连接工具

    综上所述,SQL Server连接工具是SQL Server生态系统中不可或缺的一部分,它们为数据库管理员和开发者提供了强大的支持,使得SQL Server的管理和开发工作更加高效便捷。无论是在本地环境还是云端,选择合适的工具能够...

    验证内连接和外连接实例T_sql语句

    学习内连接和外连接的实例,可以很直观的看到他们的区别。

    SQL之左连接、右连接和全连接.doc

    SQL 左连接、右连接和全连接知识点 ...左连接、右连接和全连接都是外连接操作,用于检索多个表中的记录,而内连接是内连接操作,用于检索两个表中的匹配记录。选择合适的连接操作取决于具体的应用场景和需求。

    如何连接SQL数据库

    总之,连接SQL数据库或Access数据库是开发过程中的基础工作,理解其原理和操作方法对IT初学者至关重要。无论是SQL Server的JDBC连接,还是Access的VBA或ADODB连接,都需要根据项目需求和环境选择合适的方法。通过...

    SqlDbx 数据库连接工具 可连接多个数据库

    SqlDbx是一款强大的数据库连接工具,专为数据库管理员和开发人员设计,支持连接多种类型的数据库。这款工具以其高效、易用和多功能性而备受推崇。下面将详细介绍SqlDbx的功能特性以及如何使用它来连接和管理不同的...

    SqlDbx连接oracle

    SqlDbx是一款轻量级的数据库管理工具,特别适合于SQL查询和数据库开发。它以其直观的用户界面和对多种数据库系统的支持而受到青睐,包括Oracle...通过理解和配置这些文件,你可以更流畅地在SqlDbx中操作Oracle数据库。

    SQL内连接与外连接.pdf

    主要的连接类型包括内连接(INNER JOIN)和外连接(OUTER JOIN),每种都有其特定的用途和效果。 1. **内连接(INNER JOIN)** - 内连接是基本的联接操作,它返回两个表中匹配的行。匹配是基于在`ON`子句中指定的...

    ASP连接SQL2005数据库连接代码.

    本文将详细解析如何在ASP中使用不同的认证方式来连接SQL Server 2005数据库。 ### 一、Windows身份验证连接SQL Server 2005 Windows身份验证是基于Windows操作系统安全上下文的一种认证方式,它利用当前登录用户的...

    SQL内连接及外连接.doc

    本文主要讲解了SQL中的内连接(INNER JOIN)和外连接(OUTER JOIN),包括左连接(LEFT JOIN)、右连接(RIGHT JOIN)以及完整外部联接(FULL JOIN)。 1. **内连接(INNER JOIN)** 内连接是SQL中最基本的连接...

Global site tag (gtag.js) - Google Analytics