ホームページ >データベース >mysql チュートリアル >SQL Server テーブル変数にインデックスを付けることはできますか?
SQL Server テーブル変数にはインデックスを付けることができますか?
SQL Server 2000 では、従来のテーブルのようにテーブル変数に明示的にインデックスを作成することはできません。ただし、制約を定義することでインデックスを暗黙的に作成できます。
SQL Server 2000 のテーブル変数に一意のインデックスを作成する
SQL Server 2000 では、UNIQUE 制約を宣言することで、テーブル変数に一意のインデックスを作成できます。これは、制約宣言で UNIQUE キーワードを指定することで実現できます。たとえば、次のステートメントはテーブル変数を作成し、Name 列に一意のインデックスを作成します。
<code class="language-sql">DECLARE @TEMPTABLE TABLE ( [ID] [int] NOT NULL PRIMARY KEY ,[Name] [nvarchar] (255) COLLATE DATABASE_DEFAULT NULL ,UNIQUE NONCLUSTERED ([Name], [ID]) )</code>UNIQUE 制約を使用して一意のインデックスを暗黙的に作成することで、Name 列に重複した値が許可されなくなり、Name 列に効果的にインデックスが作成され、データの取得が高速化されます。
テーブル変数のその他のインデックス タイプ
SQL Server 2000 はテーブル変数に対する一意でないインデックスの作成をサポートしていないことに注意してください。さらに、テーブル変数にクラスター化インデックスを明示的に作成することはできません。ただし、サロゲート キーまたは一意の識別子列を使用して、非一意のクラスター化インデックスをシミュレートできます。以上がSQL Server テーブル変数にインデックスを付けることはできますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。