SQL Cross Join子句

本教程将学习和演示如何使用SQL CROSS JOIN生成连接表的笛卡尔积。

1. SQL CROSS JOIN子句简介

交叉连接是一种连接操作,它生成两个或多个表的笛卡尔积。

在数学中,笛卡尔积是一种返回多组产品集的数学运算。

例如,有两组集合:A {x,y,z}B {1,2,3}A x B的笛卡尔乘积是所有有序对(x,1)(x,2)(x,3)(y,1),(y,2)(y,3)(z,1)(z,2)(z,3)

下图说明了AB的笛卡尔积:

类似地,在SQL中,两个表AB的笛卡尔乘积是结果集,其中第一个表(A)中的每一行与第二个表(B)中的每一行配对。 假设A表有n行,而B表有m行,那么AB表的交叉连接结果有n x m行。

以下是CROSS JOIN子句的语法:

SELECT column_list
FROM A
CROSS JOIN B;

下图说明了表A和表B之间的交叉连接的结果。在图中,表A具有三行记录:1,23,而表B也具有三行记录:xyz。 那么笛卡尔积结果有九行:

注意,与INNER JOINLEFT JOINFULL OUTER JOIN不同,CROSS JOIN子句没有连接条件。

以下语句等同于使用上面的CROSS JOIN子句的语句:

SELECT 
    column_list
FROM
    A,
    B;

2. SQL CROSS JOIN示例

我们将创建两个用于演示交叉连接的新表:

  • sales_organization表存储销售组织。
  • sales_channel表存储销售渠道。

以下语句用于创建sales_organizationsales_channel表:

-- 创建表1
CREATE TABLE sales_organization (
    sales_org_id INT PRIMARY KEY,
    sales_org VARCHAR (255)
);

-- 创建表2
CREATE TABLE sales_channel (
    channel_id INT PRIMARY KEY,
    channel VARCHAR (255)
);

假设该公司有两个国内(Domestic)和出口(Export)销售组织,负责国内和国际市场的销售。

以下语句将两个销售组织插入sales_organization表:

INSERT INTO sales_organization (sales_org_id, sales_org)
VALUES
    (1, 'Domestic'),
    (2, 'Export');

该公司可以通过批发(Wholesale),零售(Retail),电子商务(eCommerce)和电视购物(TV Shopping)等各种渠道分销商品。 以下语句将销售渠道插入sales_channel表:

INSERT INTO sales_channel (channel_id, channel)
VALUES
    (1, 'Wholesale'),
    (2, 'Retail'),
    (3, 'eCommerce'),
    (4, 'TV Shopping');

要查找销售组织可以拥有的所有可能的销售渠道,可以使用CROSS JOINsales_organnel表与sales_channel表连接,如下所示:

SELECT
    sales_org,
    channel
FROM
    sales_organization
CROSS JOIN sales_channel;

执行上面查询语句,得到以下结果 -

结果集包括sales_organizationsales_channel表中的所有行记录。

以下查询等效于使用上面的CROSS JOIN子句的语句:

SELECT
    sales_org,
    channel
FROM
    sales_organization,
    sales_channel;

在某些数据库系统(如PostgreSQLOracle)中,可以使用INNER JOIN子句,其条件始终求值为true以执行交叉连接,例如:

SELECT
    sales_org,
    channel
FROM
    sales_organization
INNER JOIN sales_channel ON 1 = 1;

在本教程中,学习了如何使用SQL CROSS JOIN子句生成两个或多个表的笛卡尔积。


猿狮妹
2022-12-03
SQLCrossJoin 子句 在线教程
热门教程
1 SQL复制表 如果要将SQL表复制到同一数据库中的另一个表中,可以使用select语句。从一个表复制到另一个表的语法如下:SELECT * INTO FROM 例如,可以使用以下语句将hr_employee表的记录复制到employee表中。SELECT * INTO employee FROM hr_employee;注意:SELECT INTO与INSERT INTO语句完全不同...
2 SQL Max()函数 在本教程中,您将学习如何使用SQL Max函数查找组中的最大值。1. SQL MAX函数简介SQL提供MAX()函数,用于在一组值中查找最大值。 以下是MAX函数的语法。MAX(expression)MAX函数忽略NULL值。与SUM,COUNT和AVG函数不同,DISTINCT选项不适用于MAX函数。2. SQL MAX函数示例...
3 SQL Sum()函数 在本教程中,我们将演示如何使用SQL SUM函数,此函数计算所有值或不同值的总和。1. SQL SUM函数简介SQL SUM函数是一个聚合函数,它返回所有或不同值的总和。需要注意的是,只能将SUM函数应用于数字列。以下说明了SUM函数的语法。SUM([ALL|DISTINCT] expression)ALL运算符用于将聚合应用于所有值。 SUM函数默认使用ALL运算符。例如,如果有一组集合值:(1,2,3,3,NULL)。 使用SUM函数将返回9,请注意,SUM函...
4 SQL Insert语句 在本教程中,我们将学习如何使用SQL INSERT语句来将数据插入表中。1. SQL INSERT语句简介SQL提供了INSERT语句,用于将一行或多行插入表中。 INSERT语句用于:向表中插入一行向表中插入多行将行从一个表复制到另一个表中。...
5 SQL Count()函数 本教程将向您展示如何使用SQL COUNT函数来获取组中的项目数。1. SQL COUNT函数简介SQL COUNT函数是一个聚合函数,它返回符合条件行数。 可以使用SELECT语句中的COUNT函数来获取员工数量,每个部门的员工数量,指定工作岗位的员工数量等。以下是SQL COUNT函数的语法:COUNTC ([ALL | DISTINCT] expression);COUNT函数的结果取决于传递给它的参数。默认情况下,COUNT函数使用ALL关键字,无论是否...
6 SQL Update语句 在本教程中,您将学习如何使用SQL UPDATE语句来修改表中现有行的数据。
7 SQL Order By排序 本教程将演示如何使用SQL ORDER BY子句根据指定的标准按升序或降序对结果集进行排序。1. SQL ORDER BY子句简介当使用SELECT语句查询表中的数据时,结果集中显示的行的顺序可能与您的预期不符。在某些情况下,结果集中显示的行按其物理存储在表中的顺序排列。 但是,如果查询优化器使用索引来处理查询,则行记录将显示为它们以索引键顺序存储。 因此,结果集中的行顺序未确定或不可预测。查询优化器是数据库系统中的内置软件组件,用于确定SQL语句查询请求数据的最有效方...
8 SQL自连接 本教程将向您展示如何使用SQL自连接技术将表连接到自身。1. SQL自连接简介有时,将表连接到自身是很有用的。 这种类型的连接称为自连接。我们将一张表连接到自身来评估同一个表中其他行的行。 要执行自联接,我们使用内连接或左连接子句。因为同一个表在单个查询中出现两次,所以必须使用表别名。 以下语句说明了如何将表连接到自身。...
9 SQL检查约束 在本教程中,将学习如何使用SQL CHECK约束来验证基于布尔表达式的列或一组列中的数据。1. SQL CHECK约束简介CHECK约束是SQL中的完整性约束,它允许您指定列或列集中的值必须满足布尔表达式。您可以在单个列或整个表上定义CHECK约束。 如果在单个列上定义CHECK约束,则CHECK约束仅检查此列的值。 但是,如果在表上定义CHECK约束,则会根据同一行的其他列中的值限制列中的值。...
10 SQL Delete语句 在本教程中,您将学习如何使用SQL DELETE语句删除表中的一行或多行。1. SQL DELETE语句简介要从表中删除一行或多行,请使用DELETE语句。 DELETE语句的一般语法如下:
  • Copyright © 2021 猿狮院, All rights reserved.