@

本博客翻译自两篇博客的:

1. cross join简介

MySQL cross join是mysql中的一种连接方式,区别于内连接和外连接,对于cross join连接来说,其实使用的就是笛卡尔连接。在MySQL中,当CROSS JOIN不使用WHERE子句时,CROSS JOIN产生了一个结果集,该结果集是两个关联表的行的乘积。通常,如果每个表分别具有n和m行,则结果集将具有n*m行

引用https://www.w3resource.com/mysql/advance-query-in-mysql/mysql-cross-join.php的图片,如图演示了cross join的过程,这个过程其实就是笛卡尔连接查询

2. cross join用法

cross join用法:

SELECT * FROM t1
CROSS JOIN t2;

注意:cross join的时候是不需要on或者using关键字的,这个是区别于inner join和join的

如果WHERE在条件表中添加一个子句t1并t2具有关系,则CROSS JOIN该INNER JOIN子句的工作方式类似于以下查询中所示:

SELECT * FROM t1
CROSS JOIN t2
WHERE t1.id = t2.id;

ok,再列举一下cross join表作为衍生表的例子

SELECT *
FROM table111
LEFT JOIN(table112 CROSS JOIN table113)
ON table111.id=table113.id;

ok,介绍了cross join的简单用法,现在拿http://www.mysqltutorial.org/mysql-cross-join/的例子来介绍:

首先,创建一个新数据库salesdb:

CREATE DATABASE IF NOT EXISTS salesdb;

其次,将当前数据切换到新数据库testdb:

USE testdb;

在salesdb数据库中创建新表:

  • 该表 products包含产品主数据,其中包括产品ID,产品名称和销售价格。
  • 该表stores包含出售产品的商店。
  • 该表sales包含按数量和日期在特定商店中出售的产品。

CREATE TABLE products (
id INT PRIMARY KEY AUTO_INCREMENT,
product_name VARCHAR(100),
price DECIMAL(13,2 )
); CREATE TABLE stores (
id INT PRIMARY KEY AUTO_INCREMENT,
store_name VARCHAR(100)
); CREATE TABLE sales (
product_id INT,
store_id INT,
quantity DECIMAL(13 , 2 ) NOT NULL,
sales_date DATE NOT NULL,
PRIMARY KEY (product_id , store_id),
FOREIGN KEY (product_id)
REFERENCES products (id)
ON DELETE CASCADE ON UPDATE CASCADE,
FOREIGN KEY (store_id)
REFERENCES stores (id)
ON DELETE CASCADE ON UPDATE CASCADE
);

将数据插入三个表中。假设我们有三个产品iPhone,iPad并且Macbook Pro其在两个商店出售North和South。

INSERT INTO products(product_name, price)
VALUES('iPhone', 699),
('iPad',599),
('Macbook Pro',1299); INSERT INTO stores(store_name)
VALUES('North'),
('South'); INSERT INTO sales(store_id,product_id,quantity,sales_date)
VALUES(1,1,20,'2017-01-02'),
(1,2,15,'2017-01-05'),
(1,3,25,'2017-01-05'),
(2,1,30,'2017-01-02'),
(2,2,35,'2017-01-05');

ok,业务场景:现在要统计每个商店每种商品总共营业额是多少钱?

很显然,用SUM(quantity * price),再group by一下就可以,这个sql很好写

SELECT
sto.`store_name`,
pro.`product_name`,
SUM(quantity * price) AS revenue
FROM
sales sal
INNER JOIN stores sto
ON sto.`id` = sal.`store_id`
INNER JOIN products pro
ON sal.`product_id` = pro.`id`
GROUP BY sto.`store_name`,pro.`product_name`;



ok,看了一下,发现没卖出的商品是没统计出来的,所以不太符合业务需求,业务是要统计所有的商店商品,所以可以用cross join笛卡尔连接,得出所有的商店商品组合数据

笛卡尔查询组合数据sql:

SELECT
a.`store_name`,
b.product_name
from stores cross join products

前面统计sql已经有了,所以将组合数据SQL和统计数据的SQL进行关联:

SELECT
a.`store_name`,
b.product_name,
IFNULL(c.revenue, 0) AS revenue
FROM
stores a
CROSS JOIN products b
LEFT JOIN
(SELECT
sto.`id` AS store_id,
pro.`id` AS product_id,
sto.`store_name`,
pro.`product_name`,
SUM(quantity * price) AS revenue
FROM
sales sal
INNER JOIN stores sto
ON sto.`id` = sal.`store_id`
INNER JOIN products pro
ON sal.`product_id` = pro.`id`
GROUP BY sto.`store_name`,
pro.`product_name`) c
ON a.id = c.store_id
AND b.id = c.product_id
ORDER BY a.store_name ;

请注意,IFNULL如果收入为NULL (在商店没有销售的情况下),查询使用该函数返回0。

通过CROSS JOIN这种方式使用该子句,您可以回答广泛的问题,例如,按销售员,月份查找销售收入,即使该销售员在特定月份没有销售。

ok,本博客是翻译两篇英文博客的:

ok,本博客内容翻译自两篇英文博客,不过本博客进行一定修整,将两篇博客内容进行理解整合成这篇中文博客,原因是这两篇博客的例子还是不错的,举出了cross join的常用使用场景,当然除了两篇博客提出的用法,cross join因为其笛卡尔连接的特性,还可以用于批量写数据,对应批量的写法,可以参考我之前的MySQL博客,本博客性质属于翻译的,所以转载请注明出处

MySQL应用之CROSS JOIN用法简介教程的更多相关文章

  1. MySQL基础之STRAIGHT JOIN用法简介

    MySQL基础之STRAIGHT JOIN用法简介 引用mysql官方手册的说法: STRAIGHT_JOIN is similar to JOIN, except that the left tab ...

  2. T-SQL 中的CROSS JOIN用法(半翻译)

    突然发现个很吊的链接,我们来看看学习数据库要做些什么,胆小慎点:DBA工作内容!!!! 今天来翻译一篇关于T-SQL的文章,本文可供微软认证70-461:QueryingMicrosoft SQL S ...

  3. mysql join用法简介

    为什么需要join 为什么需要join?join中文意思为连接,连接意味着关联即将一个表和多个表之间关联起来.在处理数据库表的时候,我们经常会发现,需要从多个表中获取信息,将多个表的多个字段数据组装起 ...

  4. MySQL基础之Natural Join用法

    Natural join即自然连接,natural join等同于inner join或inner using,其作用是将两个表中具有相同名称的列进行匹配 用https://www.w3resourc ...

  5. Oracle define用法简介教程

    目录 1.define常量用法 2.&和&&符号用法 继上一篇博客Oracle绑定变量学习笔记,再写一篇define变量的简单教程 @ 1.define常量用法 注意:defi ...

  6. left join,right join用法简介

    方法一(推荐): select a.man_id,man_name,d.sex_name,zw_name,c.money from man as a left join zw as b on a.zw ...

  7. SQL夯实基础(一):inner join、outer join和cross join的区别

    一.数据构建 先建表,再说话 create database Test use Test create table A ( AID ,) primary key, name ), age int ) ...

  8. MYSQL学习笔记 (三)JOIN用法

    数据库的操作分开增删改查,其中查询操作基本占系统的90%,大家所说的优化SQL语句基本是优化查询语句.接下来将学习JOIN的用法,JOIN包括:INNER JOIN(内连接).LEFT JOIN(左外 ...

  9. MySQL的几种连接 join/inner join/cross join/逗号/left join/right join/natural join

    转载请注明出处!! 之前数据表连接操作多使用逗号或者join,对几种连接的概念一直浑浑噩噩,最近研究了一波,把这些连接的区别搞明白了.   连接:A xjoin B(主表 操作 关联表)  selec ...

随机推荐

  1. 【pycharm】Unable to save settings: Failed to save settings. Please restart PyCharm解决

    1.Unable to save settings: Failed to save settings. Please restart PyCharm解决 将工程的.idea目录删掉,重启pycharm ...

  2. APScheduler学习

    说明 APScheduler是一个 Python 定时任务框架,使用起来十分方便.提供了基于日期.固定时间间隔以及 crontab 类型的任务,并且可以持久化任务.并以 daemon 方式运行应用. ...

  3. qq cookie

    qq cookie from selenium import webdriver from selenium.webdriver import ActionChains import time, re ...

  4. 【解决】MySQL提示启动成功,实际进程并没有起来

    一.概括: 1.查看运行日志 vim /var/log/mariadb/mariadb.log 2.修改配置文件 vim /etc/my.cnf 3.修改文件权限 chown mysql.mysql ...

  5. django.db.utils.OperationalError: (1093, "You can't specify target table 'xxx' for update in FROM clause")

    这个错误的意思是,不能在update某张表的where条件中,再次select这张表的某些值作为筛选条件,比如: update message set content = "hello&qu ...

  6. RabbitMQ与Spring的框架整合之Spring Cloud Stream实战

    1.RabbitMQ与Spring Cloud Stream整合实战.SpringCloud Stream整体结构核心概念图,如下所示: 图示解释:Outputs输出,即消息的发送端.Inputs输入 ...

  7. Java集合专题

    1.Java 中常用的容器有哪些? 常见容器主要包括 Collection 和 Map 两种,Collection 存储着对象的集合,而 Map 存储着键值对(两个对象)的映射表. Collectio ...

  8. 关于kubernetes我们还有什么可做的?

    kubernetes在容器编排大战中由于应用的可移植性以及支持混合云/多云部署方式上的灵活性.加上开放可扩展的理念,使得周边社区非常活跃.从既有调研结果看,kubernetes已成为容器编排领域的标准 ...

  9. Linux 操作系统的权限为什么是1,2,4 而不是 1,2,3?如何用二进制来做权限管理

    1.二进制做权限的优点 大家都知道,在Linux操作系统中,x - 可执行权限,w - 可写权限 , r - 可读权限.其权限值分别是1,2,4,但是有没有想过为什么是1,2,4 而不是 1,2,3 ...

  10. HTML 本地存储

    HTML 本地存储:优于 cookies. 什么是 HTML 本地存储? 通过本地存储(Local Storage),web 应用程序能够在用户浏览器中对数据进行本地的存储. 在 HTML5 之前,应 ...