ALTER TABLE column_definition (Transact-SQL)
適用対象: SQL Server Azure SQL Database Azure SQL Managed Instance Microsoft Fabric のウェアハウス
ALTER TABLE を使用してテーブルに追加される列のプロパティを指定します。
構文
column_name <data_type>
[ FILESTREAM ]
[ COLLATE collation_name ]
[ NULL | NOT NULL ]
[
[ CONSTRAINT constraint_name ] DEFAULT constant_expression [ WITH VALUES ]
| IDENTITY [ ( seed , increment ) ] [ NOT FOR REPLICATION ]
]
[ ROWGUIDCOL ]
[ SPARSE ]
[ ENCRYPTED WITH
( COLUMN_ENCRYPTION_KEY = key_name ,
ENCRYPTION_TYPE = { DETERMINISTIC | RANDOMIZED } ,
ALGORITHM = 'AEAD_AES_256_CBC_HMAC_SHA_256'
) ]
[ MASKED WITH ( FUNCTION = ' mask_function ') ]
[ <column_constraint> [ ...n ] ]
<data type> ::=
[ type_schema_name . ] type_name
[ ( precision [ , scale ] | max |
[ { CONTENT | DOCUMENT } ] xml_schema_collection ) ]
<column_constraint> ::=
[ CONSTRAINT constraint_name ]
{ { PRIMARY KEY | UNIQUE }
[ CLUSTERED | NONCLUSTERED ]
[
WITH FILLFACTOR = fillfactor
| WITH ( < index_option > [ , ...n ] )
]
[ ON { partition_scheme_name ( partition_column_name )
| filegroup | "default" } ]
| [ FOREIGN KEY ]
REFERENCES [ schema_name . ] referenced_table_name [ ( ref_column ) ]
[ ON DELETE { NO ACTION | CASCADE | SET NULL | SET DEFAULT } ]
[ ON UPDATE { NO ACTION | CASCADE | SET NULL | SET DEFAULT } ]
[ NOT FOR REPLICATION ]
| CHECK [ NOT FOR REPLICATION ] ( logical_expression )
}
引数
column_name
変更、追加、または削除する列の名前を指定します。 column_name は 1 ~ 128 文字で指定できます。 timestamp データ型で作成された新しい列の場合は、column_nameを省略できます。 timestamp データ型の列に対して column_name を指定しない場合には、名前 timestamp が使われます。
[ type_schema_name. ] type_name
追加する列のデータ型と、それが属するスキーマを指定します。
type_name は次のいずれかです。
Microsoft SQL Server システム データ型。
SQL Server システム データ型に基づく別名データ型。 別名データ型は、テーブル定義で使用する前に、
CREATE TYPE
を使用して作成する必要があります。Microsoft .NET Framework ユーザー定義型とそれが属するスキーマ。 .NET Framework ユーザー定義型をテーブル定義で使用するには、先に CREATE TYPE を使って作成しておく必要があります。
type_schema_name を指定しない場合、Microsoft データベース エンジンは次の順序で type_name を参照します。
SQL Server のシステム データ型
現在のデータベースにおける現在のユーザーの既定のスキーマ。
現在のデータベースの dbo スキーマ。
有効桁数 (precision)
指定されるデータ型の有効桁数です。 有効桁数の詳細については、「有効桁数、小数点以下桁数、および長さ (Transact-SQL)」を参照してください。
scale
指定されるデータ型の小数点以下桁数です。 有効な小数点以下桁数の詳細については、「有効桁数、小数点以下桁数、および長さ (Transact-SQL)」を参照してください。
max
varchar、nvarchar、varbinary データ型のみに適用されます。 これらは 2^31 バイトの文字とバイナリ データ、および 2^30 バイトの Unicode データを格納するときに使用されます。
CONTENT
column_name 内の xml データ型の各インスタンスが複数のトップレベル要素で構成できることを指定します。 CONTENT は、xml データ型のみに適用され、xml_schema_collection も指定されている場合にだけ指定できます。 指定しない場合は、CONTENT が既定の動作になります。
DOCUMENT
column_name 内の xml データ型の各インスタンスは 1 つのトップレベル要素のみで構成できることを指定します。 DOCUMENT は、xml データ型のみに適用され、xml_schema_collection も指定されている場合にだけ指定できます。
xml_schema_collection
適用対象: SQL Server 2008 (10.0.x) 以降。
xml データ型にのみ適用されます。XML スキーマ コレクションとこのデータ型を関連付けるためのものです。 xmlデータ型の列をスキーマに追加する前に、まず、CREATE XML SCHEMA COLLECTION を使用してデータベースにスキーマを作成する必要があります。
FILESTREAM
必要に応じて、type_name が varbinary(max) の列に対して FILESTREAM ストレージ属性を指定します。
列に対して FILESTREAM を指定した場合、ROWGUIDCOL 属性を持つ uniqueidentifier データ型の列がテーブルに存在する必要があります。 この列では、null 値を許可してはならず、また UNIQUE、PRIMARY KEY のいずれかの単一列制約を持つ必要があります。 列の GUID 値は、データの挿入時にアプリケーションによって、または NEWID()
関数を使用する DEFAULT 制約によって指定する必要があります。
テーブルに FILESTREAM 列が定義されている間は、ROWGUIDCOL 列を削除したり、関連する制約を変更したりすることはできません。 ROWGUIDCOL 列は、最後の FILESTREAM 列を削除した後にのみ削除できます。
列に対して FILESTREAM ストレージ属性を指定した場合、この列のすべての値がファイル システム上の FILESTREAM データ コンテナーに格納されます。
列定義の使用方法を示す例については、「FILESTREAM (SQL Server)」を参照してください。
COLLATE collation_name
列の照合順序を指定します。 指定しない場合、データベースの既定の照合順序が列に割り当てられます。 照合順序名には、Windows 照合順序名または SQL 照合順序名を指定できます。 一覧と詳細については、「Windows 照合順序名 (Transact-SQL)」と「SQL Server 照合順序名 (Transact-SQL)」を参照してください。
COLLATE 句を使用して照合順序を指定できるのは、char、varchar、nchar、nvarchar データ型の列だけです。
COLLATE 句の詳細については、「COLLATE (Transact-SQL)」を参照してください。
NULL | NOT NULL
列で NULL
値を許可するかどうかを決定します。 NULL
は厳密には制約ではありませんが、 NOT NULL
と同じように指定できます。
[ CONSTRAINT constraint_name ]
DEFAULT 値の定義の開始を指定します。 SQL Server の旧バージョンとの互換性を保つため、DEFAULT に制約名を割り当てることができます。 constraint_name は、 identifiers の規則に従う必要があります。ただし、名前を番号記号 (#
) で始めることはできません。 constraint_name を指定しない場合、DEFAULT 定義にはシステムによって作成される名前が割り当てられます。
DEFAULT
列の既定値を指定するキーワードです。 DEFAULT 定義を使用すると、既存のデータ行に新しい列の値を設定できます。 DEFAULT 定義は、timestamp 列または IDENTITY プロパティが指定されている列には適用できません。 ユーザー定義型の列に既定値を指定する場合は、その型で constant_expression 型からユーザー定義型への暗黙的な変換がサポートされている必要があります。
constant_expression
リテラル値、NULL 値、または列の既定値として使用されるシステム関数です。 .NET Framework ユーザー定義型として定義されている列と共に使用する場合は、その型を実装したときに、constant_expression からユーザー定義型への暗黙的な変換がサポートされる必要があります。
WITH VALUES では、列 と DEFAULT 制約を追加する際に列が NULL を許容している場合、WITH VALUES を使用すると、既存の行の新しい列の値は DEFAULT の constant_expression で指定される値に設定されます。
追加する列が NULL を許容していない場合、既存の行のその列の値は常に DEFAULT の constant expression で指定される値に設定されます。 SQL Server 2012 以降では、これはメタ データ操作 オンライン操作として追加-not-null-columns-as-an-online-operationにすることができます。
関連する列が追加されない場合にこれを使用しても、影響はありません。
DEFAULT constant_expression で指定される値が、既存の行に追加される新規列に格納されることを指定します。 追加する列に NULL 値が許容され、WITH VALUES を指定した場合、新しい列には既定値が格納され、既存の行に追加されます。 NULL 値が許容される列に対して WITH VALUES を指定しない場合は、既存の行の新しい列には NULL 値が格納されます。 新しい列で NULL 値が許容されない場合は、WITH VALUES の指定に関係なく、新しい行に既定値が格納されます。
IDENTITY
新しい列が ID 列であることを指定します。 SQL Server データベース エンジンは、列に一意な増分値を設定します。 既存のテーブルに ID 列を追加すると、テーブルの既存の行にシード値と増分値を持つ識別番号が追加されます。 行の更新順序は保証されません。 識別番号は、新しく追加された行に対しても生成されます。
ID 列は通常、PRIMARY KEY 制約と組み合わせて使用し、テーブルの一意な行識別子 (ROWID) の役割を果たします。 IDENTITY プロパティは、tinyint、smallint、int、bigint、decimal(p,0) 、numeric(p,0) のいずれかの列に割り当てることができます。 ID 列は 1 つのテーブルにつき 1 つだけ作成できます。 DEFAULT キーワードとバインドされている既定値は、ID 列で使用できません。 seed と increment は両方指定するか、どちらも指定しないでください。 どちらも指定しない場合、既定値は (1,1) になります。
Note
既存のテーブル列を変更して IDENTITY プロパティを追加することはできません。
パブリッシュされたテーブルへの ID 列の追加はサポートされていません。これは、列をサブスクライバーにレプリケートするときに集約できなくなる可能性があるためです。 パブリッシャーの ID 列の値は、影響を受けるテーブルの行が物理的に格納されている順序に依存します。 行はサブスクライバーで異なる方法で格納される場合があります。そのため、同じ行に対して ID 列の値が異なる場合があります。
値の明示的な挿入を許可して列の IDENTITY プロパティを無効にするには、SET IDENTITY_INSERT を使用します。
seed
テーブルに読み込まれる先頭行で使用される値を指定します。
increment
読み込まれている前の行の ID 値に加算される増分値を指定します。
NOT FOR REPLICATION
適用対象: SQL Server 2008 (10.0.x) 以降。
IDENTITY プロパティに対して指定できます。 IDENTITY プロパティに対してこの句を指定した場合、レプリケーション エージェントが挿入操作を実行するとき ID 列の値は増加しません。
ROWGUIDCOL
適用対象: SQL Server 2008 (10.0.x) 以降。
列が、行グローバル一意識別子列であることを指定します。 ROWGUIDCOL は、uniqueidentifier 列にのみ割り当てることができ、1 つのテーブルに 1 つの uniqueidentifier 列だけを ROWGUIDCOL 列として指定できます。 ROWGUIDCOL は、ユーザー定義データ型の列には割り当てできません。
ROWGUIDCOL では、列に格納される値は一意である必要はありません。 また、ROWGUIDCOL はテーブルに新しい行を挿入しても値を自動的に生成しません。 各列に一意な値を生成するには、INSERT ステートメントで NEWID 関数を使用するか、列の既定値として NEWID 関数を指定します。 詳細については、「 NEWID (Transact-SQL) 」および「 INSERT (Transact-SQL)」を参照してください。
SPARSE
列がスパース列であることを示します。 スパース列のストレージは NULL 値用に最適化されます。 スパース列を NOT NULL として指定することはできません。 スパース列のその他の制限事項と詳細については、「スパース列の使用」を参照してください。
<column_constraint>
列制約の引数の定義については、「column_constraint (Transact-SQL)」を参照してください。
ENCRYPTED WITH
Always Encrypted 機能を使って暗号化列を指定します。 ENCRYPTED WITH
は、Microsoft Fabric の SQL データベースではサポートされていません。
COLUMN_ENCRYPTION_KEY = key_name
列の暗号化キーを指定します。 詳しくは、「CREATE COLUMN ENCRYPTION KEY (Transact-SQL)」をご覧ください。
ENCRYPTION_TYPE = { DETERMINISTIC | RANDOMIZED }
確定的な暗号化 は常に任意のプレーン テキストを指定した値の場合は、同じ暗号化された値を生成するメソッドを使用します。 決定論的な暗号化を使うことにより、等価比較を使った検索や、グループ化、暗号化された値に基づく等価結合を使ったテーブルの結合が可能になりますが、承認されていないユーザーが、暗号化された列のパターンを調べることで暗号化された値に関する情報を推測することも可能になります。 決定論的に暗号化された列で 2 つのテーブルを結合することができるのは、両方の列が同じ列暗号化キーを使って暗号化されている場合のみです。 明確な暗号化では、バイナリ 2 文字型の列の並べ替え順序を持つ列の照合順序を使用する必要があります。
暗号化をランダム化 は低い予測可能な方法でデータを暗号化するためのメソッドを使用します。 ランダム化された暗号化は、より安全ですが、SQL Server インスタンスでセキュア エンクレーブを使用する Always Encrypted がサポートされる場合を除き、暗号化された列に対する計算とインデックス作成はすべて阻止されます。
Always Encrypted (セキュア エンクレーブなし) を使用している場合、政府の ID 番号などのパラメーターまたはグループ化パラメーターで検索される列には、決定論的な暗号化を使用します。 ランダム化された暗号化を使用します。クレジット カード番号などのデータは、他のレコードとグループ化されていないか、テーブルの結合に使用され、他の列 (トランザクション番号など) を使用して、目的の暗号化された列を含む行を検索するために検索されません。
セキュア エンクレーブを使用する Always Encrypted を使用する場合は、ランダム化された暗号化が推奨される暗号化の種類です。
列は、該当するデータ型である必要があります。
ALGORITHM
適用対象: SQL Server 2016 (13.x) 以降、SQL Database。
'AEAD_AES_256_CBC_HMAC_SHA_256' を指定する必要があります。
機能の制約などについて詳しくは、「Always Encrypted (データベース エンジン)」をご覧ください。
ADD MASKED WITH (FUNCTION = ' mask_function ')
適用対象: SQL Server 2016 (13.x) 以降、SQL Database。
動的なデータ マスクを指定します。 mask_function マスキング関数は、適切なパラメーターの名前を指定します。 以下の関数を使用できます。
default()
email()
partial()
random()
関数のパラメーターについては、「動的なデータ マスキング」を参照してください。
解説
追加される列が uniqueidentifier データ型の場合は、NEWID() 関数を使用する既定値を定義することで、テーブル内にある既存の各行の新しい列に一意の識別子値を設定できます。
データベース エンジンでは、列定義において DEFAULT、IDENTITY、ROWGUIDCOL または列制約を指定する場合に順序は適用されません。
列を追加すると、データ行サイズが 8,060 バイトを超える場合、ALTER TABLE ステートメントは失敗します。
例
例については、「ALTER TABLE (Transact-SQL)」を参照してください。