Mysql常用sql语句(15)- cross join 交叉连接
2024-09-01 16:50:01
测试必备的Mysql常用sql语句
https://www.cnblogs.com/poloyy/category/1683347.html
前言
- 交叉连接就是求多表之间的笛卡尔积
- 讲道理..这个我都不怎么常用..因为能用到的地方太少了;但还是要介绍的啦
啥是笛卡尔积
这属于数学的内容,不介绍概念,直接看栗子来知道吧!
假设,有两个集合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 <表1> CROSS JOIN <表2> [WHERE]
SELECT <字段名> FROM <表1>, <表2> [WHERE子句]
先看看dept、emp表有什么数据
dept表
emp表
cross join单独使用的栗子
select * from emp cross join dept;
总记录数 = emp记录数(9) * dept记录数(4) = 36
cross join + where 的栗子
select * from emp as a cross join dept as b on a.dept_id = b.id;
最新文章
- Java 代码完成删除文件、文件夹操作
- 第二轮冲刺-Runner站立会议03
- js调用.net后台事件、后台调用前台以及js调用服务器控件
- OpenCV 学习之路(1)
- 咏南IOCP中间件
- NOIP2010 关押罪犯 (并查集)
- 【avalon】createMap
- (文件描述符0、1、2),(stdin、stdout、stderr),(终端设备)这三者之间的关系???
- IOS开发UI篇之──自定义UIActionSheet
- 【BZOJ2793】【数学】[Poi2012]Vouchers
- JLINK烧写BIN文件到nand、norflash、SDRAM
- 关于用模拟器运行百度地图API无法定位的问题 - 不能用模拟器
- 201521123038 《Java程序设计》 第八周学习总结
- Kubernetes 笔记 08 Deployment 副本管理 重新招一个员工来填坑
- python3 多线程的使用
- JDK 5~8的特性对比
- 以太坊如何使用CPU挖矿?
- Factory Method
- 数学之美——HMM模型(一)介绍
- jenkins与SonarQube集成