如表   
  -------------------------------------------------   
  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

转自:http://323229113.blog.163.com/blog/static/2185362820070172553209/

【转】SQL中内连接和外连接的更多相关文章

  1. mysql,SQL标准,多表查询中内连接,外连接,自然连接等详解之查询结果集的笛卡尔积的演化

    先附上数据. CREATE TABLE `course` ( `cno` ) NOT NULL, `cname` ) CHARACTER SET utf8 NOT NULL, `ctime` ) NO ...

  2. SQL中的连接可以分为内连接,外连接,以及交叉连接 。

    SQL中的连接可以分为内连接,外连接,以及交叉连接 . 1. 交叉连接CROSS JOIN 如果不带WHERE条件子句,它将会返回被连接的两个表的笛卡尔积,返回结果的行数等于两个表行数的乘积: 举例, ...

  3. 【SQL】SQL中笛卡尔积、内连接、外连接的数据演示

    SQL的查询语句中,常使用到内连接.外连接,以及连接的基础--笛卡尔积运算. 在简单的SQL中,也许我们还分辨清楚数据如何连接,一旦查询复杂了,脑子也犯浆糊了,迷迷糊糊的. 本文,简单以数据形式记录连 ...

  4. SQL Server中内连接和外连接的区别

    SQL Server中内连接和外连接的区别 假设一个数据库中有两张表,一张是学生表StudentInfo,一张是班级表ClassInfo,两张表之间用ClassId字段进行关联. 如果用内连接,正常的 ...

  5. SQL中内连接和外连接的问题!

    本文系转载,版权归原作者所有. 如表      -------------------------------------------------      table1 | table2 |    ...

  6. SQL Server中的连接查询(内连接、外连接、交叉连接)

    在数据库查询中,经常会用到两个有关联的表进行查询,需要把两个表中的数据按照某些条件查出来,这时就可以使用连接查询 连接查询分为三种:内连接.外连接和交叉连接 1. 内连接 内连接inner join ...

  7. 你真的会玩SQL吗?和平大使 内连接、外连接

    你真的会玩SQL吗?系列目录 你真的会玩SQL吗?之逻辑查询处理阶段 你真的会玩SQL吗?和平大使 内连接.外连接 你真的会玩SQL吗?三范式.数据完整性 你真的会玩SQL吗?查询指定节点及其所有父节 ...

  8. SQL - 内连接与外连接

    PDF下载地址:SQL-内连接与外连接.pdf 连接查询在关系型数据库中经常用到,是多表联合查询的基础. 主要包含:内连接,外连接,交叉连接. SQL - 内连接与外连接 内连接 等值连接 不等值连接 ...

  9. 转:SQL的内连接与外连接

    参考:http://www.cuiyongjian.com/post-130.html 在oracle的SQL语句常用的连接有内连接(inner join),外连接(outer join)等,内连接又 ...

随机推荐

  1. neutron中的dhcp功能

    1. 分布式dhcp 特点: 1)一个dhcp port对应多个host上的tap设备. 2)基于port event的network与agent的绑定与解绑定,即创建tap设备.namespace. ...

  2. yii2系统定义的常用路径别名

    @yii 表示Yii框架所在的目录,也是 yii\BaseYii 类文件所在的位置: @app 表示正在运行的应用的根目录,一般是 digpage.com/frontend :物理路径 @vendor ...

  3. 【BZOJ-1406】密码箱 约数 + 乱搞 + set?

    1406: [AHOI2007]密码箱 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 1143  Solved: 677[Submit][Status][ ...

  4. 【poj2079】 Triangle

    http://poj.org/problem?id=2079 (题目链接) 题意 求凸包内最大三角形面积 Solution 旋转卡壳. 只会n²的做法,但是竟然过了.就是枚举每一个点,然后旋转卡壳另外 ...

  5. 洛谷P1202 [USACO1.1]黑色星期五Friday the Thirteenth

    题目描述 13号又是一个星期五.13号在星期五比在其他日子少吗?为了回答这个问题,写一个程序,要求计算每个月的十三号落在周一到周日的次数.给出N年的一个周期,要求计算1900年1月1日至1900+N- ...

  6. Linux Communication Mechanism Summarize

    目录 . Linux通信机制分类简介 . 控制机制 0x1: 竞态条件 0x2: 临界区 . Inter-Process Communication (IPC) mechanisms: 进程间通信机制 ...

  7. linux内存回收 内核参数

    ss -atu| awk '/^tcp/{++S[$2]} END {for(a in S) print a,S[a]}' ps up pid (RSS:实际内存大小,长驻内存) ps o pid,c ...

  8. java中不带package和带package的编译运行方式

    Java中不带package的程序和带package的程序编译的方式是不同的. 一.不带package的程序建立个HelloWorld.java的文件,放入C:\,内容如下:public class ...

  9. pthread_rwlock

    读写锁   1.概述 读写锁与互斥量类似,不过读写锁允许更高的并行性.互斥量要么是锁住状态,要么是不加锁状态,而且一次只有一个线程对其加锁.读写锁可以有三种状态:读模式下加锁状态,写模式下加锁状态,不 ...

  10. MySQL使用痕迹清理~/.mysql_history

    mysql会给出我们最近执行的SQL命令和脚本:同linux command保存在~/.bash_history一样,你用mysql连接MySQL server的所有操作也会被记录到~/.mysql_ ...