ADO.NET Provider for Amazon Redshift

Build 23.0.8839

インデックス

Indexes コレクションをクエリして、主キーのようなインデックスに関する情報を取得できます。

主キー情報を取得

このスキーマコレクションを取得するには、RedshiftConnection クラスのGetSchema メソッドを呼び出します。結果は、テーブル名に基づいて制限できます。 次の例は、Amazon Redshift テーブル"sales_db"."public".Orders の主キーを取得します。

C#

String connectionString = "User=admin;Password=admin;Database=dev;Server=examplecluster.my.us-west-2.redshift.amazonaws.com;Port=5439;";

using (RedshiftConnection conn = new RedshiftConnection(connectionString)) {
  conn.Open();
  DataTable databaseSchema = conn.GetSchema("Indexes", new string[] {"sales_db","public","Orders"});
  foreach (DataRow row in databaseSchema.Rows) {
    Console.WriteLine(row["INDEX_NAME"]);
    Console.WriteLine(row["PRIMARY"]);
  }
}

VB.NET

Dim connectionString As String = "User=admin;Password=admin;Database=dev;Server=examplecluster.my.us-west-2.redshift.amazonaws.com;Port=5439;"

Using conn As New RedshiftConnection(connectionString)
  conn.Open()
  Dim databaseSchema As DataTable = conn.GetSchema("Indexes",  New String() {"sales_db","public","Orders"})
  For Each row As DataRow In databaseSchema.Rows
    Console.WriteLine(row("INDEX_NAME"))
    Console.WriteLine(row("PRIMARY"))
  Next
End Using

返されたカラム

Indexes スキーマコレクションは、次のカラムを含みます。

カラム名データ型説明
INDEX_CATALOGSystem.Stringインデックスを含むデータベースの名前。
INDEX_SCHEMASystem.Stringインデックスを含むスキーマの名前。
TABLE_NAMESystem.Stringインデックスを含むテーブルの名前。
INDEX_NAMESystem.Stringインデックスの名前。
UNIQUESystem.Booleanインデックスが固有かどうか。
PRIMARYSystem.Booleanインデックスが主キーかどうか。
TYPESystem.Int32インデックスタイプに対応する整数値:statistic (0)、clustered (1)、hashed (2)、またはother (3)。
COMMENTSystem.Stringインデックスの説明。

Copyright (c) 2024 CData Software, Inc. - All rights reserved.
Build 23.0.8839