本文系转载,版权归原作者所有。

如表   

  -------------------------------------------------   

  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中内连接和外连接的问题!的更多相关文章

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

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

  2. 【转】SQL中内连接和外连接

    如表     -------------------------------------------------     table1 | table2 |     ----------------- ...

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

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

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

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

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

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

  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. MySQl数据库必会sql语句加强版

    这篇承接上一篇<mysql必会sql语句>:http://blog.csdn.net/qq_32059827/article/details/51763950 这一篇属于加强版,问题和sq ...

  2. Android的搜索框SearchView的用法-android学习之旅(三十九)

    SearchView简介 SearchView是搜索框组件,他可以让用户搜索文字,然后显示.' 代码示例 这个示例加了衣蛾ListView用于为SearchView增加自动补全的功能. package ...

  3. J2EE学习从菜鸟变大鸟之七 Servlet

    Servlet现在自己的理解是一个控制器,简单的可以理解为不同的JSP页面由用户发送过来的请求可以由Servlet控制器来控制其向下调用的方向(结合三层好理解),但它比较特殊,因为它通常会从外界接收数 ...

  4. ASP.NET实现网页版小优盘

    今天看到了一篇不错的文章,就拿来一起分享一下吧. 实现的是文件的上传与下载功能. 关于文件上传: 谈及文件上传到网站上,首先我们想到的就是通过什么上传呢?在ASP.NET中,只需要用FileUploa ...

  5. 欢迎进入我的个人博客 anzhan.me

    CSDN的博客依旧会更新,但是还是专注于技术. 个人的博客 http://anzhan.me 不单单会同步csdn的技术文章,还会有个人的更多私人的分享,包括旅行日记.欢迎各位朋友经常去看看,大家有私 ...

  6. APACHE,NGINX 详细分析

    Apache是目前最流行的Web应用服务器,占据了互联网应用服务器70%以上的份额.Apache能取得如此成功并不足为奇:它免费.稳定且性能卓越:但Apache能取得如此佳绩的另一个原因是,当时互联网 ...

  7. Spring Security3 - MVC 整合教程

    下面我们将实现关于Spring Security3的一系列教程.  最终的目标是整合Spring Security + Spring3MVC  完成类似于SpringSide3中mini-web的功能 ...

  8. OJ题:输入一个多位的数字,求各数位相加。

    题目内容: 输入一个多位的数字,1求各数位相加. 例如输入12345,则计算1+2+3+4+5=15 输入格式: 一个整数 输出格式: 一个整数 输入样例: 1234567890 输出样例: 45 时 ...

  9. 10、Libgdx的内存管理

    (官网:www.libgdx.cn) 游戏是非常耗资源的应用.图片和音效可能耗费大量的内存,另一方面来说,这些资源没有被Java垃圾回收,让一个垃圾处理来决定将显存中的5M的图片进行释放也不是一个明知 ...

  10. Android事件总线分发库EventBus3.0的简单讲解与实践

    Android事件总线分发库EventBus的简单讲解与实践 导语,EventBus大家应该不陌生,EventBus是一款针对Android优化的发布/订阅事件总线.主要功能是替代Intent,Han ...