热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

MySQL应用之CROSSJOIN用法

1.crossjoin简介MySQLcrossjoin是mysql中的一种连接方式,区别于内连接和外连接,对于crossjoin连接来说,其实使用的就是笛卡尔连接。在MySQL中,


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用法:



  1. SELECT * FROM t1

  2. CROSS JOIN t2;


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


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



  1. SELECT * FROM t1

  2. CROSS JOIN t2

  3. WHERE t1.id = t2.id;

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



  1. SELECT *

  2. FROM table111

  3. LEFT JOIN(table112 CROSS JOIN table113)

  4. ON table111.id=table113.id;

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

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



  1. CREATE DATABASE IF NOT EXISTS salesdb;

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



  1. USE testdb;

在salesdb数据库中创建新表:



  • 该表 products包含产品主数据,其中包括产品ID,产品名称和销售价格。

  • 该表stores包含出售产品的商店。

  • 该表sales包含按数量和日期在特定商店中出售的产品。

    CREATE TABLE products (



    1. id INT PRIMARY KEY AUTO_INCREMENT,

    2. product_name VARCHAR(100),

    3. price DECIMAL(13,2 )

    );

    CREATE TABLE stores (



    1. id INT PRIMARY KEY AUTO_INCREMENT,

    2. store_name VARCHAR(100)

    );

    CREATE TABLE sales (



    1. product_id INT,

    2. store_id INT,

    3. quantity DECIMAL(13 , 2 ) NOT NULL,

    4. sales_date DATE NOT NULL,

    5. PRIMARY KEY (product_id , store_id),

    6. FOREIGN KEY (product_id)

    7. REFERENCES products (id)

    8. ON DELETE CASCADE ON UPDATE CASCADE,

    9. FOREIGN KEY (store_id)

    10. REFERENCES stores (id)

    11. ON DELETE CASCADE ON UPDATE CASCADE

    );



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



  1. INSERT INTO products(product_name, price)

  2. VALUES('iPhone', 699),

  3. ('iPad',599),

  4. ('Macbook Pro',1299);


  5. INSERT INTO stores(store_name)

  6. VALUES('North'),

  7. ('South');


  8. INSERT INTO sales(store_id,product_id,quantity,sales_date)

  9. VALUES(1,1,20,'2017-01-02'),

  10. (1,2,15,'2017-01-05'),

  11. (1,3,25,'2017-01-05'),

  12. (2,1,30,'2017-01-02'),

  13. (2,2,35,'2017-01-05');

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

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



  1. SELECT

  2. sto.`store_name`,

  3. pro.`product_name`,

  4. SUM(quantity * price) AS revenue

  5. FROM

  6. sales sal

  7. INNER JOIN stores sto

  8. ON sto.`id` = sal.`store_id`

  9. INNER JOIN products pro

  10. ON sal.`product_id` = pro.`id`

  11. GROUP BY sto.`store_name`,pro.`product_name`;

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

笛卡尔查询组合数据sql:



  1. SELECT

  2. a.`store_name`,

  3. b.product_name

  4. from stores cross join products

在这里插入图片描述

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



  1. SELECT

  2. a.`store_name`,

  3. b.product_name,

  4. IFNULL(c.revenue, 0) AS revenue

  5. FROM

  6. stores a

  7. CROSS JOIN products b

  8. LEFT JOIN

  9. (SELECT

  10. sto.`id` AS store_id,

  11. pro.`id` AS product_id,

  12. sto.`store_name`,

  13. pro.`product_name`,

  14. SUM(quantity * price) AS revenue

  15. FROM

  16. sales sal

  17. INNER JOIN stores sto

  18. ON sto.`id` = sal.`store_id`

  19. INNER JOIN products pro

  20. ON sal.`product_id` = pro.`id`

  21. GROUP BY sto.`store_name`,

  22. pro.`product_name`) c

  23. ON a.id = c.store_id

  24. AND b.id = c.product_id

  25. ORDER BY a.store_name ;

在这里插入图片描述

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

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

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



  • http://www.mysqltutorial.org/mysql-cross-join/

  • https://www.w3resource.com/mysql/advance-query-in-mysql/mysql-cross-join.php

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



推荐阅读
  • 本文探讨了如何在 PHP 的 Eloquent ORM 中实现数据表之间的关联查询,并通过具体示例详细解释了如何将关联数据嵌入到查询结果中。这不仅提高了数据查询的效率,还简化了代码逻辑。 ... [详细]
  • MySQL索引详解与优化
    本文深入探讨了MySQL中的索引机制,包括索引的基本概念、优势与劣势、分类及其实现原理,并详细介绍了索引的使用场景和优化技巧。通过具体示例,帮助读者更好地理解和应用索引以提升数据库性能。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 本文介绍如何通过创建替代插入触发器,使对视图的插入操作能够正确更新相关的基本表。涉及的表包括:飞机(Aircraft)、员工(Employee)和认证(Certification)。 ... [详细]
  • MySQL缓存机制深度解析
    本文详细探讨了MySQL的缓存机制,包括主从复制、读写分离以及缓存同步策略等内容。通过理解这些概念和技术,读者可以更好地优化数据库性能。 ... [详细]
  • MySQL 数据库迁移指南:从本地到远程及磁盘间迁移
    本文详细介绍了如何在不同场景下进行 MySQL 数据库的迁移,包括从一个硬盘迁移到另一个硬盘、从一台计算机迁移到另一台计算机,以及解决迁移过程中可能遇到的问题。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • 本文介绍如何使用Python进行文本处理,包括分词和生成词云图。通过整合多个文本文件、去除停用词并生成词云图,展示文本数据的可视化分析方法。 ... [详细]
  • 最近团队在部署DLP,作为一个技术人员对于黑盒看不到的地方还是充满了好奇心。多次咨询乙方人员DLP的算法原理是什么,他们都以商业秘密为由避而不谈,不得已只能自己查资料学习,于是有了下面的浅见。身为甲方,虽然不需要开发DLP产品,但是也有必要弄明白DLP基本的原理。俗话说工欲善其事必先利其器,只有在懂这个工具的原理之后才能更加灵活地使用这个工具,即使出现意外情况也能快速排错,越接近底层,越接近真相。根据DLP的实际用途,本文将DLP检测分为2部分,泄露关键字检测和近似重复文档检测。 ... [详细]
  • 毕业设计:基于机器学习与深度学习的垃圾邮件(短信)分类算法实现
    本文详细介绍了如何使用机器学习和深度学习技术对垃圾邮件和短信进行分类。内容涵盖从数据集介绍、预处理、特征提取到模型训练与评估的完整流程,并提供了具体的代码示例和实验结果。 ... [详细]
  • 在多线程编程环境中,线程之间共享全局变量可能导致数据竞争和不一致性。为了解决这一问题,Linux提供了线程局部存储(TLS),使每个线程可以拥有独立的变量副本,确保线程间的数据隔离与安全。 ... [详细]
author-avatar
甜心菇
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有