mysql左连接出现笛卡尔积_Mysql内连接、左连接会出现笛卡尔积的理解

先简单解释一下笛卡尔积。

现在,我们有两个集合A和B。

A = {0,1}     B = {2,3,4}

集合 A×B 和 B×A的结果集就可以分别表示为以下这种形式:

A×B = {(0,2),(1,2),(0,3),(1,3),(0,4),(1,4)};

B×A = {(2,0),(2,1),(3,0),(3,1),(4,0),(4,1)};

以上A×B和B×A的结果就可以叫做两个集合相乘的‘笛卡尔积’。

从以上的数据分析我们可以得出以下两点结论:

1,两个集合相乘,不满足交换率,既 A×B ≠ B×A;

2,A集合和B集合相乘,包含了集合A中元素和集合B中元素相结合的所有的可能性。既两个集合相乘得到的新集合的元素个数是 A集合的元素个数 × B集合的元素个数;

MySQL的多表查询(笛卡尔积原理)先确定数据要用到哪些表。

将多个表先通过笛卡尔积变成一个表。

然后去除不符合逻辑的数据(根据两个表的关系去掉)。

最后当做是一个虚拟表一样来加上条件即可。

数据库表连接数据行匹配时所遵循的算法就是以上提到的笛卡尔积,表与表之间的连接可以看成是在做乘法运算。

比如现在数据库中有两张表,student表和 student_subject表,如下所示:

61990dd9a6bb1f3ccb5d65199cfab219.png  

0918fc74568b2380d3f2fb6c17cd7600.png

我们执行以下的sql语句,只是纯粹的进行表连接。

当前内容已被隐藏,您需要登录才能查看快速登录快速注册

看一下执行结果:

mysql左连接出现笛卡尔积_Mysql内连接、左连接会出现笛卡尔积的理解_第1张图片  

mysql左连接出现笛卡尔积_Mysql内连接、左连接会出现笛卡尔积的理解_第2张图片

表1.0                            表1.1

从执行结果上来看,结果符合我们以上提出的两点结论(红线标注部分);

以第一条sql语句为例我们来看一下他的执行流程,

1,from语句把student表 和 student_subject表从数据库文件加载到内存中。

2,join语句相当于对两张表做了乘法运算,把student表中的每一

你可能感兴趣的:(mysql左连接出现笛卡尔积)