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

9f0ab672a6294ff62c9ed456804a4970.png

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

简单解释一下笛卡尔积

设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表,如下图所示:

6045b20be023758e94adab9cf7bb4d50.png

ad94b1e978eb415c121cb457f67d8d12.png

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

SELECT * FROM Teacher , Course;

输出结果:

59a625898d9df4d98b71015afd39e162.png

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

SELECT * FROM Teacher , Course

WHERE Teacher.tid=Course.tid;

输出结果:

d34988efa9d0d64f70c5ca23d52e8b5b.png

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

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值