700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > sql join on 多表连接_SQL 多表查询-交叉连接(笛卡尔积)

sql join on 多表连接_SQL 多表查询-交叉连接(笛卡尔积)

时间:2018-07-16 11:00:49

相关推荐

sql join on 多表连接_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>}

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

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;

输出结果:

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

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。