SQL Server 2008 の IDENTITY_INSERT をマスターする
このガイドでは、SQL Server 2008 での IDENTITY_INSERT
の使用法を明確にし、一般的な問題に対処し、解決策を提供します。
問題: IDENTITY_INSERT がオフのときにエラーを挿入する
SQL Server の IDENTITY_INSERT
設定は、挿入中に ID 列に値を手動で割り当てることができるかどうかを決定します。 IDENTITY_INSERT
が OFF
(デフォルト) の場合、ID 列が自動的にインクリメントされ、手動で値を割り当てることができなくなります。 ID 列に指定された値を持つ行を挿入しようとすると、エラーが発生します。
解決策: IDENTITY_INSERT の有効化と無効化
SQL Server Management Studio (SSMS) を使用することもできますが、データベース コンソールまたはクエリ エディター内で T-SQL コマンドを直接使用する方が効率的です。
よくある間違い: IDENTITY_INSERT をオフにし忘れる
注意: IDENTITY_INSERT
を使用して SET IDENTITY_INSERT ... ON
を有効にした後は、必ず SET IDENTITY_INSERT ... OFF
で無効にしてください。これを行わないと、後続の挿入で手動で値を割り当てることができ、アプリケーションが自動インクリメント動作に依存している場合に競合が発生する可能性があります。
正しい T-SQL 構文
適切な構文は次のとおりです:
有効にする:
<code class="language-sql">SET IDENTITY_INSERT YourTableWithIdentityColumn ON;</code>
無効にする:
<code class="language-sql">SET IDENTITY_INSERT YourTableWithIdentityColumn OFF;</code>
エラー メッセージについて
「IDENTITY_INSERT が OFF に設定されている場合、テーブル 'YourTableWithIdentityColumn' の ID 列に明示的な値を挿入できません」というエラーは、IDENTITY_INSERT
が無効になっているときに ID 列に事前定義された値を挿入しようとしたことを示します。
この改善された明確さは、ユーザーが IDENTITY_INSERT
を使用するときによくある落とし穴を回避するのに役立ちます。 使用後は必ず電源を切ることを忘れないでください。
以上がSQL Server 2008 の IDENTITY_INSERT: 有効化、無効化、およびエラーのトラブルシューティングを行う方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。