> 데이터 베이스 > MySQL 튜토리얼 > 笛卡尔积与交叉联接

笛卡尔积与交叉联接

WBOY
풀어 주다: 2016-06-07 15:22:09
원래의
1916명이 탐색했습니다.

1 笛卡尔积定义 设A,B为集合,用A中元素为第一元素,B中元素为第二元素构成的有序对,所有这样的有序对组成的集合叫做A与B的笛卡尔积,记作AxB。 例如,A={a,b},B={0,1,2},则 AxB={a,o,a,1,a,2,b,0,b,1,b,2,} BxA={0,a,0,b,1,a,1,b,2,a,2,b} 2 交差联接 交差

1 笛卡尔积定义

设A,B为集合,用A中元素为第一元素,B中元素为第二元素构成的有序对,所有这样的有序对组成的集合叫做A与B的笛卡尔积,记作AxB。

例如,A={a,b},B={0,1,2},则

AxB={,,,,,,}

BxA={,,,,,}

2 交差联接

交差联接是笛卡尔积在SQL中的实现,SQL中使用关键字“CROSS JOIN”来表示交差联接。

例如:存在表tb_Class及表tb_Student,两表拥有的数据如下图所示。

\

\

对两表进行交叉连接查询:

喎?http://www.2cto.com/kf/ware/vc/" target="_blank" class="keylink">vcD4KPHByZSBjbGFzcz0="brush:sql;">SELECT * FROM tb_Class a CROSS JOIN tb_Student b SELECT * FROM tb_Student c CROSS JOIN tb_Class d

得到以下查询结果:

\

3 小知识

1) 交叉连接不能使用ON关键字,但可以使用WHERE子句定义连接条件。

SELECT * FROM tb_Class a CROSS JOIN tb_Student b WHERE a.classid=b.classid
로그인 후 복사
\
此时,与以下查询结果一致。

SELECT * FROM tb_Class a ,tb_Student b WHERE a.classid=b.classid
로그인 후 복사

所以,如果添加了WHERE子句,则交叉联接的行为将与内部联接行为相似。

2 )交叉连接返回的数据行数为第一个表中符合条件的数据行数乘以第二个表中符合条件的数据行数。

实例中的 tb_Class表有4行数据,tb_Student表有3行数据,所以返回的结果有12行。

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿