笛卡儿专题

sql server2008处理笛卡儿积的逻辑——记一次解决疑惑

环境:sql server 2008 背景:几天前,我在ssms上实验笛卡儿积——cross join/, ,发现我运行的结果不太正常——重复元组出现在右边,理解不了。众所周知,两个表进行笛卡儿积其实是从一个表的每个元组出发,依次扫描另一个表。但是,我以为这里先扫描的表是左表,经过一番测试,先扫描的表原来是元组数相对少的那个表。 测试: step1: 几天前,我依次创建了两个表:Stude

数据库原理: 笛卡儿积

笛卡儿积(Cartesian Product)是集合论中的一个概念,也在数据库中的查询操作中经常使用。笛卡儿积是指两个集合(或更多集合)之间所有可能的组合。如果有两个集合A和B,它们的笛卡儿积记作A × B,表示A中的每个元素与B中的每个元素都组成一对。 在数学符号中,如果A = {a, b} 且 B = {1, 2},那么A × B的笛卡儿积为{(a, 1), (a, 2), (b, 1)