mysql中cross,Mysql常用sql语句(15)- cross join 交叉连接

测试必备的Mysql常用sql语句,每天敲一篇,每次敲三遍,每月一循环,全都可记住!!

前言

交叉连接就是求多表之间的笛卡尔积

讲道理..这个我都不怎么常用..因为能用到的地方太少了;但还是要介绍的啦

啥是笛卡尔积

这属于数学的内容,不介绍概念,直接看栗子来知道吧!

假设,有两个集合A、B

A = {1,2}

B = {3,4}

集合A和集合B的笛卡尔积 = 集合A * 集合B;即,两表相乘,如下:

AxB = {(1,3),(1,4),(2,3),(2,4)}

在Mysql中,表与表之间的笛卡尔积不建议使用,会产生大量不合理的数据;

假设两张表各有100条记录,那么表与表的笛卡尔积的数据量就有100*100=10000条了...

cross join 的语法格式

SELECT FROM CROSS JOIN [WHERE]

SELECT FROM , [WHERE子句]

先看看dept、emp表有什么数据

dept表

a5cc3f37d63b4267233c1b12f69b7fd8.png

emp表

4ffcabc2daf82c517ef0b847897ef77b.png

cross join单独使用的栗子

select * from emp cross join dept;

6e0cafbe40f23c43fafbfa8a293f84db.png

总记录数 = emp记录数(9) * dept记录数(4) = 36

cross join + where 的栗子

select * from emp as a cross join dept as b on a.dept_id = b.id;

931140768eed666b09a7fb54cc7b8396.png

标签:join,笛卡尔,cross,dept,emp,Mysql,集合,15

来源: https://www.cnblogs.com/poloyy/p/12881918.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值