(一定要避免使用!)笛卡尔积在多表(没有任何关系的表)查询现象

交叉连接(笛卡尔积)语法:

SELECT * FROM table1 CROSS JOIN table2;
SELECT * FROM table1 JOIN table2;
SELECT * FROM table1 , table2;

SQL 多表查询-交叉连接(笛卡尔积)

交叉连接(笛卡尔积)返回被连接的两个表所有数据行的笛卡尔积,返回结果集合中的数据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。

简单解释一下笛卡尔积

设A,B为集合,用A中元素为第一元素,B中元素为第二元素构成有序对,所有这样的有序对组成的集合叫做A与B的笛卡尔积,记作AxB.

笛卡尔积的符号化为:

AxB={<x,y>|x∈A∧y∈B}

例如,A={a,b},B={0,1,2},则

AxB={<a,o>,<a,1>,<a,2>,<b,0>,<b,1>,<b,2>,}

BxA={<0,a>,<0,b>,<1,a>,<1,b>,<2,a>,<2,b>}

例如数据库中两张表(两张表可以没有任何关系),Teacher表和 Course表,如下图所示:

SQL 交叉连接语句(纯粹连接查询):

SELECT * FROM Teacher , Course;

输出结果:

SQL 交叉连接加上条件WHERE语句:

SELECT * FROM Teacher , Course WHERE Teacher.tid=Course.tid;

输出结果:

总结:由于交叉连接(笛卡尔积)返回的结果为被连接的两个数据表的乘积,当数据表量太多的时候,查询会非常慢,一般使用LEFT JOIN或者RIGHT JOIN。

猜你喜欢

转载自blog.csdn.net/weixin_45037357/article/details/108273375
今日推荐