MySQL中inner join 和 cross join 的区别

 我来答
翻译达人
2017-01-05 · 互联网+翻译,人工翻译平台
翻译达人
翻译达人(www.fanyidaren.com)顺应时代的发展,采取用互联网+翻译的模式,致力于打造一个为客户提供翻译服务的专业翻译平台,将翻译资源进行有效整合,让客户不再为找翻译而烦恼。
向TA提问
展开全部
Inner join:内连接,也叫等值连接,inner join产生同时符合A和B的一组数据。
Cross join:交叉连接,得到的结果是两个表的乘积,即笛卡尔积
笛卡尔(Descartes)乘积又叫直积。假设集合A={a,b},集合B={0,1,2},则两个集合的笛卡尔积为{(a,0),(a,1),(a,2),(b,0),(b,1), (b,2)}。可以扩展到多个集合的情况。类似的例子有,如果A表示某学校学生的集合,B表示该学校所有课程的集合,则A与B的笛卡尔积表示所有可能的选课情况。

Inner join 和 Cross join 的区别:

1、Cross join生成的是先生成笛卡尔集,然后on连接条件被视为了filter用于数据过滤,
Inner join是直接基于join condition做连接,生成的join集合就是最终的输出结果,产生的中间数据更小。
2、Inner join结合ON子句使用;Cross join用于其它地方。
3、Cross join产生的是笛卡尔集,也就是 M*N 的集合,Inner join是内联查询,不是产生笛卡尔集。
4、Cross join不加条件限制,Inner join的on是加了条件限制的
匿名用户
2016-03-02
展开全部
join的方式不同,cross join生成的是先生成笛卡尔集,然后on连接条件被视为了filter用于数据过滤,inner
join是直接基于join
condition做连接,生成的join集合就是最终的输出结果,产生的中间数据更小。实际上MySQL优化器会将这两条查询都优化成同一种join方
式,比如merge join或者nested loop
join,如果你没有开启对应的优化参数,那么MySQL只有傻傻的去按指定的方式去做join
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
幸福有你更幸福
2016-03-03 · TA获得超过1.5万个赞
知道大有可为答主
回答量:1.1万
采纳率:0%
帮助的人:838万
展开全部
name sex
张三 男
李四 女

b表
name age
李四 30
王五 23

1\全外连接
select a.name,a.sex,b.name,b.age
from a full outer join b on a.name=b.name
结果如下,
name sex name age
张三 男 NULL NULL
李四 女 李四 30
NULL NULL 王五 23
关联字段name,左表有而右表没有的,如张三,b.name,b.age都为NULL,加上左右两边都有的就是左连接的结果;而右表有而左表表没有的,如王五,a.name,a.sex都为NULL,加上左右两边都有的就是右连接的结果;左右两边都有的如,李四,这就是内连接。相见如下
2\左
select a.name,a.sex,b.name,b.age
from a left outer join b on a.name=b.name
结果如下
name sex name age
张三 男 NULL NULL
李四 女 李四 30
2\右
select a.name,a.sex,b.name,b.age
from a right outer join b on a.name=b.name
结果如下
name sex name age
李四 女 李四 30
NULL NULL 王五 23
3\内联
select a.name,a.sex,b.name,b.age
from a inner join b on a.name=b.name
结果如下
name sex name age
李四 女 李四 30
4\交叉
select a.name,a.sex,b.name,b.age
from a cross join b on a.name=b.name
结果如下
name sex name age
张三 男 李四 30
李四 女 王五 23
张三 男 王五 23
李四 女 李四 30
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式