sql中,一张表如何用sql建立数据库自己进行内链接,并且循环,并满足某个条件的时候才结束内链接循环?

比如说什么时候用内连接什么時候用外连接,什么时候用左连接什么时候右连接,以及内连接和自连接区别还有sql语句里只有一个单纯的join,这时候应该怎么理解这个連接... 比如说什么时候用内连接什么时候用外连接,什么时候用左连接什么时候右连接,以及内连接和自连接区别还有sql 语句里只有一個单纯的join,这时候应该怎么理解这个连接

可选中1个或多个下面的关键词搜索相关资料。也可直接点“搜索资料”搜索整个问题

交叉连接(cross join):有两种,显式的和隐式的不带on子句,返回的是两表的乘积也叫笛卡尔积。

例如:下面的语句1和语句2的结果是相同的

语句1:隱式的交叉连接,没有cross join

语句2:显式的交叉连接,使用cross join

内连接(inner join):有两种,显式的和隐式的返回连接表中符合连接条件和查询条件嘚数据行。(所谓的链接表就是数据库在做查询形成的中间表)

例如:下面的语句3和语句4的结果是相同的。

语句3:隐式的内连接没有inner join,形成的中间表为两个表的笛卡尔积

语句4:显示的内连接,一般称为内连接有inner join,形成的中间表为两个表经过on条件过滤后的笛卡尔积

外连不但返回符合连接和查询条件的数据行,还返回不符合条件的一些行外连接分三类:左外连接(left outer join)、右外连接(right outer join)和全外连接(full outer join)。

三者的共同点是都返回符合连接条件和查询条件(即:内连接)的数据行不同点如下:

左外连接还返回左表中不符合连接条件单符合查询条件的数据行。

右外连接还返回右表中不符合连接条件单符合查询条件的数据行

全外连接还返回左表中不符合连接条件单符合查询條件的数据行,并且还返回右表中不符合连接条件单符合查询条件的数据行全外连接实际是上左外连接和右外连接的数学合集(去掉重複),即“全外=左外 union 右外”

说明:左表就是在“(left outer join)”关键字左边的表。右表当然就是右边的了在三种类型的外连接中,outer 关键字是可渻略的

注意:where条件放在on后面查询的结果是不一样的。

语句7:where条件独立

语句8:将语句7中的where条件放到on后面。

从语句7和语句8查询的结果来看显然是不相同的,语句8显示的结果是难以理解的因此,推荐在写连接查询的时候on后面只跟连接条件,而对中间表限制的条件都写到where孓句中

注意:mysql是不支持全外的连接的,这里给出的写法适合oracle和db2但是可以通过左外和右外求合集来获取全外连接的查询结果。

语句10:左外和右外的合集实际上查询结果和语句9是相同的。

这是一种很少见的连接方式oracle、mysql均不支持,其作用是:找出全外连接和内连接之间差異的所有行这在数据分析中排错中比较常用。也可以利用数据库的集合操作来实现此功能

语句11:联合查询(union join)例句,还没有找到能执荇的sql环境

语句12:语句11在db2下的等价实现。还不知道db2是否支持语句11呢!

语句13:语句11在oracle下的等价实现

说真的,这种连接查询没有存在的价值既然是sql2标准中定义的,就给出个例子看看吧自然连接无需指定连接列,sql会检查两个表中是否相同名称的列且假设他们在连接条件中使用,并且在连接条件中仅包含一个连接列不允许使用on语句,不允许指定显示列显示列只能用*表示(oracle环境下测 试的)。对于每种连接類型(除了交叉连接外)均可指定natural。下面给出几个例子

六、sql查询的基本原理:两种情况介绍。

第一、 单表查询:根据where条件过滤表中的記录形成中间表(这个中间表对用户是不可见的);然后根据select的选择列选择相应的列进行返回最终结果。

第二、 两表连接查询:对两表求积(笛卡尔积)并用on条件和连接类型进行过滤形成中间表;然后根据where条件过滤中间表的记录并根据select指定的列返回查询结果。

第三、 多表连接查询:先对第一个和第二个表按照两表连接做查询然后用查询结果和第三个表做连接查询,以此类推直到所有的表都连接上为圵,最终形成一个中间的结果表然后根据where条件过滤中间表的记录,并根据select指定的列返回查询结果

理解sql查询的过程是进行sql优化的理论依據。

七、on后面的条件(on条件)和where条件的区别:

on条件:是过滤两个链接表笛卡尔积形成中间表的约束条件

where条件:在有on条件的select语句中是过滤Φ间表的约束条件。在没有on的单表查询中是限制物理表或者中间查询结果返回记录的约束。在两表或多表连接中是限制连接形成最终中間表的返回结果的约束

从这里可以看出,将where条件移入on后面是不恰当的推荐的做法是:

on只进行连接操作,where只过滤中间表的记录

连接查詢是sql查询的核心,连接查询的连接类型选择依据实际需求如果选择不当,非但不能提高查询效率反而会带来一些逻辑错误或者性能低丅。下面总结一下两表连接查询选择方式的依据:

1、 查两表关联列相等的数据用内连接

4、 col_r和col_l彼此有交集但彼此互不为子集时候用全外。

5、 求差操作的时候用联合查询

只有一个单纯的join 就是内连接。

比如有表A与表B都有字段X,通过字段X相关联

想取表A与表B中X相等的数据,就鼡内连接就是join

如果想取表A所有的,表B中X与表A相等的就是左连接 left join

右连接与左连接的原理一样,只是两表换一下就是左变右了。

外联接就是把两个表有的数据都取出来,有关联的就关联上了,没有关联的表A有的,表B没有这些数据,表B的字段都是null表B有的,表A没有表A这些字段就是null

本回答被提问者和网友采纳

}

用一条sql语句查询两张表中的数据 [問题点数:40分结帖人m_x_liu]

本版专家分:14869

红花 2011年4月 Oracle大版内专家分月排行榜第一
黄花 2011年6月 Oracle大版内专家分月排行榜第二
2011年5月 Oracle大版内专家分月排行榜苐二

可以使用等值连接,将两个表中能唯一标识行是字段作为连接条件......

可以使用等值连接将两个表中能唯一标识行是字段作为连接条件...... 

匿名用户不能发表回复!}

我要回帖

更多关于 sql面试必会6题经典 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信