インデックスの作成、変更、および削除
SMO (SQL Server 管理オブジェクト) 階層では、インデックスは Index オブジェクトで表現します。インデックス付き列は、IndexedColumns プロパティによって表される IndexedColumn オブジェクトのコレクションで表現します。
Index オブジェクトの IsXmlIndex プロパティを指定すると、XML 列のインデックスを作成できます。
例
提供されているコード例を使用するには、アプリケーションを作成するプログラミング環境、プログラミング テンプレート、およびプログラミング言語を選択する必要があります。詳細については、「Visual Studio .NET で Visual Basic SMO プロジェクトを作成する方法」または「Visual Studio .NET で Visual C# SMO プロジェクトを作成する方法」を参照してください。
Visual Basic での非クラスタ化複合インデックスの作成
このコード例では、非クラスタ化複合インデックスを作成する方法を示します。複合インデックスの場合、2 つ以上の列をインデックスに追加します。非クラスタ化インデックスを作成するために、IsClustered プロパティは False に設定します。
'Connect to the local, default instance of SQL Server.
Dim srv As Server
srv = New Server
'Reference the AdventureWorks database.
Dim db As Database
db = srv.Databases("AdventureWorks")
'Declare a Table object and reference the HumanResources table.
Dim tb As Table
tb = db.Tables("Employee", "HumanResources")
'Define an Index object variable by providing the parent table and index name in the constructor.
Dim idx As Index
idx = New Index(tb, "TestIndex")
'Add indexed columns to the index.
Dim icol1 As IndexedColumn
icol1 = New IndexedColumn(idx, "EmployeeID", True)
idx.IndexedColumns.Add(icol1)
Dim icol2 As IndexedColumn
icol2 = New IndexedColumn(idx, "HireDate", True)
idx.IndexedColumns.Add(icol2)
'Set the index properties.
idx.IndexKeyType = IndexKeyType.DriUniqueKey
idx.IsClustered = False
idx.FillFactor = 50
'Create the index on the instance of SQL Server.
idx.Create()
'Modify the page locks property.
idx.DisallowPageLocks = True
'Run the Alter method to make the change on the instance of SQL Server.
idx.Alter()
'Remove the index from the table.
idx.Drop()
Visual C# での非クラスタ化複合インデックスの作成
このコード例では、非クラスタ化複合インデックスを作成する方法を示します。複合インデックスの場合、2 つ以上の列をインデックスに追加します。非クラスタ化インデックスを作成するために、IsClustered プロパティは False に設定します。
{
//Connect to the local, default instance of SQL Server.
Server srv;
srv = new Server();
//Reference the AdventureWorks database.
Database db;
db = srv.Databases("AdventureWorks");
//Declare a Table object and reference the HumanResources table.
Table tb;
tb = db.Tables("Employee", "HumanResources");
//Define an Index object variable by providing the parent table and index name in the constructor.
Index idx;
idx = new Index(tb, "TestIndex");
//Add indexed columns to the index.
IndexedColumn icol1;
icol1 = new IndexedColumn(idx, "EmployeeID", true);
idx.IndexedColumns.Add(icol1);
IndexedColumn icol2;
icol2 = new IndexedColumn(idx, "HireDate", true);
idx.IndexedColumns.Add(icol2);
//Set the index properties.
idx.IndexKeyType = IndexKeyType.DriUniqueKey;
idx.IsClustered = false;
idx.FillFactor = 50;
//Create the index on the instance of SQL Server.
idx.Create();
//Modify the page locks property.
idx.DisallowPageLocks = true;
//Run the Alter method to make the change on the instance of SQL Server.
idx.Alter();
//Remove the index from the table.
idx.Drop();
}
Visual Basic での XML インデックスの作成
このコード例では、XML データ型に対して XML インデックスを作成する方法を示します。この XML データ型は、「XML スキーマの使用方法」で作成される、MySampleCollection と呼ばれる XML スキーマ コレクションです。XML インデックスにはいくつかの制限事項がありますが、その 1 つは、XML インデックスはクラスタ化主キーを既に持っているテーブルに作成する必要があるという点です。
'Connect to the local, default instance of SQL Server.
Dim srv As Server
srv = New Server()
'Reference the AdventureWorks database.
Dim db As Database
db = srv.Databases("AdventureWorks")
'Define a Table object variable and add an XML type column.
Dim tb As Table
tb = New Table(db, "XmlTable")
Dim col1 As Column
'This sample requires that an XML schema type called MySampleCollection exists on the database.
col1 = New Column(tb, "XMLValue", DataType.Xml("MySampleCollection"))
'Add another integer column that can be made into a unique, primary key.
tb.Columns.Add(col1)
Dim col2 As Column
col2 = New Column(tb, "Number", DataType.Int)
col2.Nullable = False
tb.Columns.Add(col2)
'Create the table of the instance of SQL Server.
tb.Create()
'Create a unique, clustered, primary key index on the integer column. This is required for an XML index.
Dim cp As Index
cp = New Index(tb, "clusprimindex")
cp.IsClustered = True
cp.IndexKeyType = IndexKeyType.DriPrimaryKey
Dim cpcol As IndexedColumn
cpcol = New IndexedColumn(cp, "Number", True)
cp.IndexedColumns.Add(cpcol)
cp.Create()
'Define and XML Index object variable by supplying the parent table and the XML index name arguments in the constructor.
Dim i As Index
i = New Index(tb, "xmlindex")
Dim ic As IndexedColumn
ic = New IndexedColumn(i, "XMLValue", True)
i.IndexedColumns.Add(ic)
'Create the XML index on the instance of SQL Server.
i.Create()
Visual C# での XML インデックスの作成
このコード例では、XML データ型に対して XML インデックスを作成する方法を示します。この XML データ型は、「XML スキーマの使用方法」で作成される、MySampleCollection と呼ばれる XML スキーマ コレクションです。XML インデックスにはいくつかの制限事項がありますが、その 1 つは、XML インデックスはクラスタ化主キーを既に持っているテーブルに作成する必要があるという点です。
{
//Connect to the local, default instance of SQL Server.
Server srv;
srv = new Server();
//Reference the AdventureWorks database.
Database db;
db = srv.Databases("AdventureWorks");
//Define a Table object variable and add an XML type column.
Table tb;
tb = new Table(db, "XmlTable");
Column col1;
//This sample requires that an XML schema type called MySampleCollection exists on the database.
col1 = new Column(tb, "XMLValue", DataType.Xml("MySampleCollection"));
//Add another integer column that can be made into a unique, primary key.
tb.Columns.Add(col1);
Column col2;
col2 = new Column(tb, "Number", DataType.Int);
col2.Nullable = false;
tb.Columns.Add(col2);
//Create the table of the instance of SQL Server.
tb.Create();
//Create a unique, clustered, primary key index on the integer column. This is required for an XML index.
Index cp;
cp = new Index(tb, "clusprimindex");
cp.IsClustered = true;
cp.IndexKeyType = IndexKeyType.DriPrimaryKey;
IndexedColumn cpcol;
cpcol = new IndexedColumn(cp, "Number", true);
cp.IndexedColumns.Add(cpcol);
cp.Create();
//Define and XML Index object variable by supplying the parent table and the XML index name arguments in the constructor.
Index i;
i = new Index(tb, "xmlindex");
IndexedColumn ic;
ic = new IndexedColumn(i, "XMLValue", true);
i.IndexedColumns.Add(ic);
//Create the XML index on the instance of SQL Server.
i.Create();
}