简单了解一下笛卡尔积定义和运算规则
最近在学习MYSQL JOIN语句的执行顺序和原理时,提到了笛卡尔积的概念,于是就想着了解一下笛卡尔积的概念和运用并进行记录,方便以后复习。
定义:
笛卡尔乘积是指在数学中,两个集合X和Y的笛卡尔积(Cartesian product),又称直积,表示为X × Y,第一个对象是X的成员而第二个对象是Y的所有可能有序对的其中一个成员。
假设集合A={a, b},集合B={0, 1, 2},则两个集合的笛卡尔积为{(a, 0), (a, 1), (a, 2), (b, 0), (b, 1), (b, 2)}。

R有三个属性ABC,每个属性内有三个元素,如图中R方框所示.
S有三个属性ABC,每个属性内有三个元素,如图中S方框所示.
R乘以S是这样计算的:
(每一行元素称为一个元组)
Ra Rb Rc Sa Sb Sc分别代表R中的abc属性,S中的abc三个属性.
先用R中的第一个元组分别和S中的三个元组相乘,得到如下
Ra Rb Rc Sa Sb Sc
a1 b1 c1 a1 b2 c2
a1 b1 c1 a1 b3 c3
a1 b1 c1 a2 b2 c1
再用R中的第二个元组分别和S中的三个元组相乘,得到如下
Ra Rb Rc Sa Sb Sc
a1 b2 c2 a1 b2 c2
a1 b2 c2 a1 b3 c3
a1 b2 c2 a2 b2 c1
再用R中的第三个元组分别和S中的三个元组相乘,得到如下
Ra Rb Rc Sa Sb Sc
a2 b2 c1 a1 b2 c2
a2 b2 c1 a1 b3 c3
a2 b2 c1 a2 b2 c1
最后将这三种计算出来的阵列按照Ra Rb Rc Sa Sb Sc排列好,就能得到上面右边方框中R乘以S得到的广义笛卡尔积了.
参考文档:
https://www.bilibili.com/read/cv5013688/
https://baike.baidu.com/item/%E7%AC%9B%E5%8D%A1%E5%B0%94%E4%B9%98%E7%A7%AF/6323173?fr=aladdin
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
2015-09-06 黑盒测试中的一些小经验