文档章节

SQL的内连接与外连

sms95
 sms95
发布于 2015/04/29 20:32
字数 1296
阅读 6
收藏 0
点赞 0
评论 0

转自:http://pangaoyuan.javaeye.com/blog/713177

有两个表A和表B。
  表A结构如下:
  Aid:int;标识种子,主键,自增ID
  Aname:varchar
  数据情况,即用select * from A出来的记录情况如下图1所示:

表B结构如下:
  Bid:int;标识种子,主键,自增ID
  Bnameid:int
  数据情况,即用select * from B出来的记录情况如下图2所示:

图2:B表数据

  为了把Bid和Aid加以区分,不让大家有误解,所以把Bid的起始种子设置为100。
  有SQL基本知识的人都知道,两个表要做连接,就必须有个连接字段,从上表中的数据可以看出,在A表中的Aid和B表中的Bnameid就是两个连接字段。
  下图3说明了连接的所有记录集之间的关系:



图3:连接关系图
现在我们对内连接和外连接一一讲解。
  1.内连接:利用内连接可获取两表的公共部分的记录,即图3的记录集C
  语句如下:Select * from A JOIN B ON A.Aid=B.Bnameid
  运行结果如下图4所示:

图4:内连接数据

  其实select * from A,B where A.Aid=B.Bnameid与Select * from A JOIN B ON A.Aid=B.Bnameid的运行结果是一样的。
  2.外连接:外连接分为两种,一种是左连接(Left JOIN)和右连接(Right JOIN)
  (1)左连接(Left JOIN):即图3公共部分记录集C+表A记录集A1。
  语句如下:select * from A Left JOIN B ON A.Aid=B.Bnameid
  运行结果如下图5所示:


图5:左连接数据

  说明:
  在语句中,A在B的左边,并且是Left Join,所以其运算方式为:A左连接B的记录=图3公共部分记录集C+表A记录集A1
  在图3中即记录集C中的存在的Aid为:2 3 6 7 8
  图1中即表A所有记录集A中存在的Aid为:1 2 3 4 5 6 7 8 9
  表A记录集A1中存在的Aid=(图1中即A表中所有Aid)-(图3中即记录集C中存在的Aid),最终得出为:1 4 5 9
  由此得出图5中A左连接B的记录=图3公共部分记录集C+表A记录集A1,
  最终得出的结果图5中可以看出Bnameid及Bid非NULL的记录都为图3公共部分记录集C中的记录;Bnameid及Bid为NULL的Aid为1 4 5 9的四笔记录就是表A记录集A1中存在的Aid。
  (2)右连接(Right JOIN):即图3公共部分记录集C+表B记录集B1。
  语句如下:select * from A Right JOIN B ON A.Aid=B.Bnameid
 运行结果如下图6所示:
图6:右连接数据

  说明:
  在语句中,A在B的左边,并且是Right Join,所以其运算方式为:A右连接B的记录=图3公共部分记录集C+表B记录集B1
  在图3中即记录集C中的存在的Aid为:2 3 6 7 8
  图2中即表B所有记录集B中存在的Bnameid为:2 3 6 7 8 11
  表B记录集B1中存在的Bnameid=(图2中即B表中所有Bnameid)-(图3中即记录集C中存在的Aid),最终得出为:11
  由此得出图6中A右连接B的记录=图3公共部分记录集C+表B记录集B1,
  最终得出的结果图6中可以看出Aid及Aname非NULL的记录都为图3公共部分记录集C中的记录;Aid及Aname为NULL的Aid为11的记录就是表B记录集B1中存在的Bnameid。
  总结:
  通过上面的运算解说,相信很多人已经想到,上面的情况(包括图3的关系图)说明的都只是A在B的左边的情况,
  以下语句B在A的右边的又会出现什么情况呢??
  select * from B Left JOIN A ON A.Aid=B.Bnameid
  select * from B Right JOIN A ON A.Aid=B.Bnameid
  其实对图3左右翻转一下就可以得出以下结论:
  select * from B Left JOIN A ON A.Aid=B.Bnameid和select * from A Right JOIN B ON A.Aid=B.Bnameid所得出的记录集是一样的
   而
  select * from B Right JOIN A ON A.Aid=B.Bnameid和select * from A Left JOIN B ON A.Aid=B.Bnameid所得出的记录集也是一样的。


Another  Demo from http://mouer.javaeye.com/blog/901153

在oracle的SQL语句常用的连接有内连接(inner join),外连接(outer join)等,内连接又包括等值连接,非等值连接,自连接;而外连接又分为左连接和右连接。其中默认的是内连接的等值连接。

内连接:利用内连接(等值)就可获取公共部分C,图中的数据集C.

select * from A inner join B on A.Aid=B.Bid;等价于select * from A,B where A.Aid=B.Bid 图中C的部分

外连接:分为左外连接(left join)与右外连接(right join)
左外连接:select * from A,B where A.Aid=B.Bid(+);等价于select * from A left outer joinB on A.id=B.id图中A+C的部分

右外连接:select * from A,B where A.Aid(+)=B.Bid;等价于select * from Aright outer joinB on A.id=B.id图中B+C的部分



© 著作权归作者所有

共有 人打赏支持
sms95
粉丝 1
博文 31
码字总数 22644
作品 0
长沙
5Python全站之路系列之MySL连表查询

Python全栈之路系列之MySQL连表查询 普通的连表查询,把一个的结果当作另外一个的参数 SELECT * FROM personnel.person_info where personnel.person_info.part_nid in (SELECT nid from per...

Edenwy
2017/05/15
0
0
Hibernate查询、 检索、 抓取 (Fetch)

一、HQL 在hql中关键字不区分大小写,但属性和类名区分大小写 简单属性查询 * 单一属性查询,返回结果集属性列表 * 多个属性查询,返回集合元素是对象数组,数组长度取决于select中属性个数 ...

程海峰
2013/06/04
0
0
mysql 连接查询(俗称连表查询)

连接查询的分类 本文讨论中用到的测试数据 create table student( id int primary key auto_increment, name varchar(10) ); insert into student values (null,'xiaohong'), (null,'xiaomi......

20130902
05/01
0
0
Django查询优化之select_related和prefetch_related

一、select_related查询优化 select_related通过多表join关联查询,一次性获得所有数据,通过降低数据库查询次数来提升性能,但关联表不能太多,因为join操作本来就比较消耗性能。本文通过D...

daibaiyang119
2017/10/30
0
0
mysql 内链接/外链接/交叉链接

1.内链接(典型的链接运算,使用=或<>之类的比较运算)内链接使用比较运算符根据每个表共有的列的值匹配两个表中的行。例如,检索students和coursesb表中的学生标识号相同的所有行。 2.外链接...

hyhlinux
2016/07/06
52
0
Linq to EF 内连接和左外连接

一、内连接 内连接与SqL中inner join一样,即找出两个序列的交集 Model1Container model = new Model1Container(); 与上面的内连接语句相对应的SQL脚本语言如下所示: SELECT [t0].[CourseC...

可达鸭眉头一皱
2016/12/15
9
0
史上最简单的 MySQL 教程(二十七)「连接查询(下)」

连接查询 连接查询:将多张表(大于等于 2 张表)按照某个指定的条件进行数据的拼接,其最终结果记录数可能有变化,但字段数一定会增加。 连接查询的意义:在用户查询数据的时候,需要显示的...

qq_35246620
2017/07/14
0
0
PowerPivot 和 SQL Azure 快速入门

公告:本博客为微软云计算中文博客的镜像博客。部分文章因为博客兼容性问题,会影响阅读体验。如遇此情况,请访问原博客。 PowerPivot是一款微软Excel 2010 的可下载 插件 ,其强大功能允许您...

晨曦之光
2012/03/09
0
0
SQL学习精粹之内外连接以及where和on条件的区别

sql内外连接(重点) 在oracle的SQL语句常用的连接有内连接(inner join),外连接(outer join)等,内连接又包括等值连接,非等值连接,自连接;而外连接又分为左连接和右连接全连接。其中...

颖辉小居
2016/10/31
22
0
java socket内网连接外网问题

如果我写socket软件,服务端在外网,我该怎么连接?如果都是内网又该怎么连接?我搞糊涂了,写了个远程控制,但是只能内网连接,外网连不上,请前辈给我讲解一下。

kidbei
2012/09/13
1K
2

没有更多内容

加载失败,请刷新页面

加载更多

下一页

Tomcat内存设置

第一步骤: 1、路径是Tomcat目录下的/bin/catalina.bat文件 打开catalina.bat文件 加入下面这句代码: set JAVA_OPTS=%JAVA_OPTS% -server -XX:PermSize=128M -XX:MaxPermSize=512m 2、路径是...

一梦心草
8分钟前
0
0
IDEA 及 Gradle 使用总结

IDEA 及 Gradle 使用总结 自动编译组件 目前Android开发的主流开发工具是 Eclipse 和 IDEA 目前主流的自动化打包工具时 ant,maven,gradle。 maven工具中有自己的依赖仓库维护,很多开源支持...

舒文joven
8分钟前
0
0
lombok 引入后,测试类始终找不到get,set方法。

开发环境为idea,jdk1.7,maven3.5. 网上直接搜出来的方法有: 1、在setting里安装lombok的plugins; 2、如下图,勾选enable annocation processing选项 3、升级maven plugins插件 我尝试了以...

Kidult
10分钟前
0
0
Duang,HUAWEI DevEco IDE全面升级啦

想感受全新UI带来的视觉及交互体验、 HiKey970开发板调测、 HiAI API推荐和收藏、 深度AI模型分析等新功能, 体验高清晰度和流畅度的远程AI真机调测吗? 全新的UI设计 采用最优秀的视觉及交互...

华为终端开放实验室
18分钟前
0
0
阻止事件冒泡,阻止默认事件

1.event.stopPropagation()方法 这是阻止事件的冒泡方法,不让事件向documen上蔓延,但是默认事件任然会执行,当你掉用这个方法的时候,如果点击一个连接,这个连接仍然会被打开, 2.event....

闫亚亚
20分钟前
0
0
网络监控工具类

package com.guorentong.learn.organ.utils;import android.app.Activity;import android.content.Context;import android.content.Intent;import android.net.ConnectivityManage......

王先森oO
20分钟前
0
0
命令

sudo nginx -s reload 重启nginx sudo lsof -i -P | grep -i "listen" 查看端口占用

那个猴子
24分钟前
0
0
用scrapy-redis爬去新浪-以及把数据存储到

需求:爬取新浪网导航页(http://news.sina.com.cn/guide/)所有下所有大类、小类、小类里的子链接,以及子链接页面的新闻内容。 准备工作: a.安装redis(windows或者linux) b.安装Redis Des...

丁典
25分钟前
0
0
PHP常用函数篇

1.为什么要使用函数? 除了内建的PHP函数,我们可以创建我们自己的函数。 函数是可以在程序中重复使用的语句块。 使代码逻辑更清晰 避免过多的全局变量 封装后避免相同逻辑重复代码,只需调用...

天地有涯风有信_大海无量不见人
25分钟前
0
0
对List分组

在日常工作中会遇到这样的情景,我们需要对List按照List中对象的一个值进行分组。比如一个Human的List,我们要根据性别分组,传统的方法是做双层循环,逐个对比,今天我要介绍一种详单简单的...

珂jack
27分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部