hierarchyid データ型を使用したテーブルの作成

EmployeeOrg という名前のテーブルを作成する例を次に示します。このテーブルには、従業員データと、それらの従業員のレポート階層が含まれています。この例では、テーブルを AdventureWorks2008R2 データベースに作成しますが、これは任意です。例をわかりやすくするために、このテーブルには 5 つの列のみ含まれています。

  • OrgNode は、階層リレーションシップを格納する hierarchyid 列です。

  • OrgLevel は OrgNode 列に基づく計算列であり、階層内での各ノードのレベルが格納されます。これは、幅優先のインデックスに使用されます。

  • EmployeeID には、給与処理などのアプリケーションで使用される通常の従業員識別番号が含まれます。新しいアプリケーションの開発では、アプリケーションは OrgNode 列を使用でき、この個別の EmployeeID 列は不要です。

  • EmpName には、従業員の名前が含まれます。

  • Title には、従業員の役職が含まれます。

EmployeeOrg テーブルを作成するには

  1. クエリ エディター ウィンドウで、次のコードを実行し、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
    
  2. 次のコードを実行して OrgLevel 列と OrgNode 列に複合インデックスを作成し、効率的な幅優先の検索をサポートします。

    CREATE UNIQUE INDEX EmployeeOrgNc1 
    ON HumanResources.EmployeeOrg(OrgLevel, OrgNode) ;
    GO
    

これでテーブルはデータを受け入れる準備ができました。次に、階層的な手法を使用してテーブルにデータを入力します。