交叉连接(笛卡尔积)返回被连接的两个表所有数据行的笛卡尔积,返回结果集合中的数据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。
简单解释一下笛卡尔积
设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>}
交叉连接(笛卡尔积)语法:
SELECT * FROM table1 CROSS JOIN table2;
SELECT * FROM table1 JOIN table2;
SELECT * FROM table1 , table2;
例如数据库中两张表,Teacher表和 Course表,如下图所示:
SQL 交叉连接语句(纯粹连接查询):
SELECT * FROM Teacher , Course;
输出结果:
SQL 交叉连接加上条件WHERE语句:
SELECT * FROM Teacher , Course
WHERE Teacher.tid=Course.tid;
输出结果:
由于交叉连接(笛卡尔积)返回的结果为被连接的两个数据表的乘积,当数据表量太多的时候,查询会非常慢,一般使用LEFT JOIN或者RIGHT JOIN
如果觉得对您有一丢丢帮助,请点击右下角【在看】,让更多人看到该文章。
长按识别二维码
关注获取视频资料