W3Cschool
恭喜您成為首批注冊用戶
獲得88經(jīng)驗值獎勵
本章討論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)這兩個表在EmployeeNo列上連接時,不會發(fā)生重新分配,因為EmployeeNo是正在連接的兩個表的主索引。
考慮以下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 );
如果這兩個表在DeparmentNo列上連接,那么這些行需要重新分布,因為DepartmentNo是一個表中的主索引和另一個表中的非主索引。 在這種情況下,加入行可能不在同一個AMP上。 在這種情況下,Teradata可能會在DepartmentNo列重新分發(fā)employee表。
對于上述Employee和Department表,如果Department表的大小較小,Teradata可能會復(fù)制所有AMP上的Department表。
嵌套連接不使用所有AMP。 對于嵌套連接發(fā)生,其中一個條件應(yīng)該是一個表的唯一主索引上的相等,然后將此列連接到另一個表上的任何索引。
在這種情況下,系統(tǒng)將使用一個表的唯一主索引獲取一行,并使用該行哈希從其他表獲取匹配的記錄。 嵌套連接是所有Join方法中最有效的。
Product Join將來自一個表的每個限定行與來自其他表的每個限定行進(jìn)行比較。 產(chǎn)品加入可能由于以下某些因素而發(fā)生:
Copyright©2021 w3cschool編程獅|閩ICP備15016281號-3|閩公網(wǎng)安備35020302033924號
違法和不良信息舉報電話:173-0602-2364|舉報郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號
聯(lián)系方式:
更多建議: