zoukankan      html  css  js  c++  java
  • 数据库左连接、右连接、内连接、全连接区别

    基本定义:  

      left join (左连接):返回包括左表中的所有记录和右表中连接字段相等的记录。
      right join (右连接):返回包括右表中的所有记录和左表中连接字段相等的记录。
      inner join (等值连接或者叫内连接):只返回两个表中连接字段相等的行。
      full join (全外连接):返回左右表中所有的记录和左右表中连接字段相等的记录。

    1、内联接(典型的联接运算,使用像 =  或 <> 之类的比较运算符)。包括相等联接和自然联接。     
      内联接使用比较运算符根据每个表共有的列的值匹配两个表中的行。例如,检索 students和courses表中学生标识号相同的所有行。   
        
    2、外联接。外联接可以是左向外联接、右向外联接或完整外部联接。     
      在 FROM子句中指定外联接时,可以由下列几组关键字中的一组指定:     

      1)LEFT  JOIN或LEFT OUTER JOIN     
      左向外联接的结果集包括  LEFT OUTER子句中指定的左表的所有行,而不仅仅是联接列所匹配的行。如果左表的某行在右表中没有匹配行,则在相关联的结果集行中右表的所有选择列表列均为空值。       

      2)RIGHT  JOIN 或 RIGHT  OUTER  JOIN     
      右向外联接是左向外联接的反向联接。将返回右表的所有行。如果右表的某行在左表中没有匹配行,则将为左表返回空值。       
      3)FULL  JOIN 或 FULL OUTER JOIN
      完整外部联接返回左表和右表中的所有行。当某行在另一个表中没有匹配行时,则另一个表的选择列表列包含空值。如果表之间有匹配行,则整个结果集行包含基表的数据值。   
        
    3、交叉联接   
      交叉联接返回左表中的所有行,左表中的每一行与右表中的所有行组合。交叉联接也称作笛卡尔积。    
      FROM 子句中的表或视图可通过内联接或完整外部联接按任意顺序指定;但是,用左或右向外联接指定表或视图时,表或视图的顺序很重要。有关使用左或右向外联接排列表的更多信息,请参见使用外联接。     

    示例:

     A表          
     
      id   name  
     
      1  小王
     
      2  小李
     
      3  小刘
     
      B表
     
      id  A_id  job
     
      1  2    老师
     
      2  4    程序员

    内连接:(只有2张表匹配的行才能显示)

    select a.name,b.job from A a  inner join B b on a.id=b.A_id
     
      只能得到一条记录
     
      小李  老师

    左连接:(左边的表不加限制)

    select a.name,b.job from A a  left join B b on a.id=b.A_id
     
      三条记录
     
      小王  null
     
      小李  老师
     
      小刘  null

    右连接:(右边的表不加限制)

    select a.name,b.job from A a  right join B b on a.id=b.A_id
     
      两条记录
     
      小李  老师
     
      null  程序员

    全外连接:(左右2张表都不加限制)

    select a.name,b.job from A a  full join B b on a.id=b.A_id
     
      四条数据
     
      小王  null
     
      小李  老师
     
      小刘  null
     
      null  程序员

    注:在sql中l外连接包括左连接(left join )和右连接(right join),全外连接(full join),等值连接(inner join)又叫内连接。

    参考:https://blog.csdn.net/weixin_39220472/article/details/81193617

         https://www.cnblogs.com/afirefly/archive/2010/10/08/1845906.html

  • 相关阅读:
    [数字证书] 怎么打开windows的数字证书管理器
    [RF] 安装好Robot Framework之后怎样让启动的界面后面不带命令行窗口,且图片以机器人显示
    [RF]怎样用Robot Framework写好Test Case?
    iptables的疑问
    centos6.5安装jenkins文档部署全过程
    haproxy+keepalived以及haproxy的原理特点
    rhel6.5安装ansible
    客户端执行rsync出现的错误
    LVS_DR 安装后无法转发真实服务器,但是配置其他方面都检查的没有问题了。就剩在realserver这边没有在lo口上绑定VIP了
    架构设计:负载均衡层设计方案(1)——负载场景和解决方式
  • 原文地址:https://www.cnblogs.com/116970u/p/11448737.html
Copyright © 2011-2022 走看看