hierarchyid データ型を使用したテーブルの作成
EmployeeOrg という名前のテーブルを作成する例を次に示します。このテーブルには、従業員データと、それらの従業員のレポート階層が含まれています。この例では、テーブルを AdventureWorks2008R2 データベースに作成しますが、これは任意です。例をわかりやすくするために、このテーブルには 5 つの列のみ含まれています。
OrgNode は、階層リレーションシップを格納する hierarchyid 列です。
OrgLevel は OrgNode 列に基づく計算列であり、階層内での各ノードのレベルが格納されます。これは、幅優先のインデックスに使用されます。
EmployeeID には、給与処理などのアプリケーションで使用される通常の従業員識別番号が含まれます。新しいアプリケーションの開発では、アプリケーションは OrgNode 列を使用でき、この個別の EmployeeID 列は不要です。
EmpName には、従業員の名前が含まれます。
Title には、従業員の役職が含まれます。
EmployeeOrg テーブルを作成するには
クエリ エディター ウィンドウで、次のコードを実行し、EmployeeOrg テーブルを作成します。OrgNode 列を、クラスター化インデックスのある主キーとして指定すると、深さ優先のインデックスが作成されます。
USE AdventureWorks2008R2 ; GO CREATE TABLE HumanResources.EmployeeOrg ( OrgNode hierarchyid PRIMARY KEY CLUSTERED, OrgLevel AS OrgNode.GetLevel(), EmployeeID int UNIQUE NOT NULL, EmpName varchar(20) NOT NULL, Title varchar(20) NULL ) ; GO
次のコードを実行して OrgLevel 列と OrgNode 列に複合インデックスを作成し、効率的な幅優先の検索をサポートします。
CREATE UNIQUE INDEX EmployeeOrgNc1 ON HumanResources.EmployeeOrg(OrgLevel, OrgNode) ; GO
これでテーブルはデータを受け入れる準備ができました。次に、階層的な手法を使用してテーブルにデータを入力します。