インデックス
Indexes コレクションをクエリして、主キーのようなインデックスに関する情報を取得できます。
主キー情報を取得
このスキーマコレクションを取得するには、IBMCloudObjectStorageConnection クラスのGetSchema メソッドを呼び出します。結果は、テーブル名に基づいて制限できます。 次の例は、IBM Cloud Object Storage テーブルObjects の主キーを取得します。
C#
String connectionString = "ApiKey=myApiKey;CloudObjectStorageCRN=MyInstanceCRN;Region=myRegion;OAuthClientId=MyOAuthClientId;OAuthClientSecret=myOAuthClientSecret;"; using (IBMCloudObjectStorageConnection conn = new IBMCloudObjectStorageConnection(connectionString)) { conn.Open(); DataTable databaseSchema = conn.GetSchema("Indexes", new string[] {"Objects"}); foreach (DataRow row in databaseSchema.Rows) { Console.WriteLine(row["INDEX_NAME"]); Console.WriteLine(row["PRIMARY"]); } }
VB.NET
Dim connectionString As String = "ApiKey=myApiKey;CloudObjectStorageCRN=MyInstanceCRN;Region=myRegion;OAuthClientId=MyOAuthClientId;OAuthClientSecret=myOAuthClientSecret;" Using conn As New IBMCloudObjectStorageConnection(connectionString) conn.Open() Dim databaseSchema As DataTable = conn.GetSchema("Indexes", New String() {"Objects"}) For Each row As DataRow In databaseSchema.Rows Console.WriteLine(row("INDEX_NAME")) Console.WriteLine(row("PRIMARY")) Next End Using
返されたカラム
Indexes スキーマコレクションは、次のカラムを含みます。
カラム名 | データ型 | 説明 |
INDEX_CATALOG | System.String | インデックスを含むデータベースの名前。 |
INDEX_SCHEMA | System.String | インデックスを含むスキーマの名前。 |
TABLE_NAME | System.String | インデックスを含むテーブルの名前。 |
INDEX_NAME | System.String | インデックスの名前。 |
UNIQUE | System.Boolean | インデックスが固有かどうか。 |
PRIMARY | System.Boolean | インデックスが主キーかどうか。 |
TYPE | System.Int32 | インデックスタイプに対応する整数値:statistic (0)、clustered (1)、hashed (2)、またはother (3)。 |
COMMENT | System.String | インデックスの説明。 |