W3Cschool
恭喜您成為首批注冊(cè)用戶
獲得88經(jīng)驗(yàn)值獎(jiǎng)勵(lì)
本章討論Teradata中可用的各種JOIN策略。
CREATE SET TABLE EMPLOYEE,FALLBACK ( EmployeeNo INTEGER, FirstName VARCHAR(30) , LastName VARCHAR(30) , DOB DATE FORMAT 'YYYY-MM-DD', JoinedDate DATE FORMAT 'YYYY-MM-DD', DepartmentNo BYTEINT ) UNIQUE PRIMARY INDEX ( EmployeeNo );
CREATE SET TABLE Salary ( EmployeeNo INTEGER, Gross INTEGER, Deduction INTEGER, NetPay INTEGER ) UNIQUE PRIMARY INDEX(EmployeeNo);
當(dāng)這兩個(gè)表在EmployeeNo列上連接時(shí),不會(huì)發(fā)生重新分配,因?yàn)镋mployeeNo是正在連接的兩個(gè)表的主索引。
考慮以下Employee和Department表。
CREATE SET TABLE EMPLOYEE,FALLBACK ( EmployeeNo INTEGER, FirstName VARCHAR(30) , LastName VARCHAR(30) , DOB DATE FORMAT 'YYYY-MM-DD', JoinedDate DATE FORMAT 'YYYY-MM-DD', DepartmentNo BYTEINT ) UNIQUE PRIMARY INDEX ( EmployeeNo );
CREATE SET TABLE DEPARTMENT,FALLBACK ( DepartmentNo BYTEINT, DepartmentName CHAR(15) ) UNIQUE PRIMARY INDEX ( DepartmentNo );
如果這兩個(gè)表在DeparmentNo列上連接,那么這些行需要重新分布,因?yàn)镈epartmentNo是一個(gè)表中的主索引和另一個(gè)表中的非主索引。 在這種情況下,加入行可能不在同一個(gè)AMP上。 在這種情況下,Teradata可能會(huì)在DepartmentNo列重新分發(fā)employee表。
對(duì)于上述Employee和Department表,如果Department表的大小較小,Teradata可能會(huì)復(fù)制所有AMP上的Department表。
嵌套連接不使用所有AMP。 對(duì)于嵌套連接發(fā)生,其中一個(gè)條件應(yīng)該是一個(gè)表的唯一主索引上的相等,然后將此列連接到另一個(gè)表上的任何索引。
在這種情況下,系統(tǒng)將使用一個(gè)表的唯一主索引獲取一行,并使用該行哈希從其他表獲取匹配的記錄。 嵌套連接是所有Join方法中最有效的。
Product Join將來(lái)自一個(gè)表的每個(gè)限定行與來(lái)自其他表的每個(gè)限定行進(jìn)行比較。 產(chǎn)品加入可能由于以下某些因素而發(fā)生:
Copyright©2021 w3cschool編程獅|閩ICP備15016281號(hào)-3|閩公網(wǎng)安備35020302033924號(hào)
違法和不良信息舉報(bào)電話:173-0602-2364|舉報(bào)郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號(hào)
聯(lián)系方式:
更多建議: