查询语句 cross join 交叉连接

查询语句 cross join 交叉连接

前言

  • 交叉连接就是多表之间的笛卡尔积
  • 也要了解,学习学习

啥是笛卡尔积

这属于数学的内容,不用介绍概念,直接看例子!

假设,有两个集合A,B

A = {1,2}
B = {3,4}

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

  • 在MySQL中,表与表之间的笛卡尔积不建议使用,会产生大量不合理的数据;
  • 假设两张表各有100条记录,那么表与表的笛卡尔积的数据量就有100*100=10000条了…

cross join 的语法格式

SELECT <字段名> FROM <1> CROSS JOIN <2> [WHERE]
SELECT <字段名> FROM <1>, <2> [WHERE子句] 

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

在这里插入图片描述
在这里插入图片描述

SELECT * FROM emp CROSS JOIN dept;

SELECT * FROM emp A CROSS JOIN dept B ON A.dept_id = B.id;

SELECT * FROM emp,dept; 

SELECT * FROM emp,dept WHERE emp.dept_id = dept.id;

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述


版权声明:本文为weixin_50077855原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。