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

简单解释一下笛卡尔积

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

笛卡尔积的符号化为:

AxB={|x∈A∧y∈B}

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

AxB={,,,,,,}

BxA={,,,,,}

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

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

例如数据库中两张表多表查询,Teacher表和 Course表,如下图所示:

多表查询_火车表查询_sql查询a表和b表

火车表查询_多表查询_sql查询a表和b表

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

sql查询a表和b表_多表查询_火车表查询

SELECT * FROM Teacher , Course;

输出结果:

多表查询_sql查询a表和b表_火车表查询

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

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

输出结果:

火车表查询_sql查询a表和b表_多表查询

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

如果觉得对您有一丢丢帮助多表查询,请点击右下角【在看】,让更多人看到该文章。

火车表查询_sql查询a表和b表_多表查询

多表查询_火车表查询_sql查询a表和b表

长按识别二维码

关注获取视频资料