SQL Server: 条件付き挿入による重複エントリの防止
SQL Server データベースを使用する場合、データの整合性を維持するには、重複データの挿入を防ぐことが重要です。 一般的なアプローチには条件付き挿入の使用が含まれますが、多くの場合、構文の問題が発生します。 「メッセージ 156、レベル 15、キーワード 'WHERE' 付近の構文が正しくありません」というエラーは、「存在しない場合は挿入」ロジックの誤った実装によって頻繁に発生します。
解決策は、insert ステートメントを再構築することです。 「存在しない場合は挿入」を直接試みる代わりに、条件付きブロックを使用します:
<code class="language-sql">BEGIN IF NOT EXISTS (SELECT 1 FROM EmailsRecebidos WHERE De = @_DE AND Assunto = @_ASSUNTO AND Data = @_DATA) BEGIN INSERT INTO EmailsRecebidos (De, Assunto, Data) VALUES (@_DE, @_ASSUNTO, @_DATA) END END</code>
この改訂されたコードは、挿入を試行する前に、IF NOT EXISTS
を使用して、指定された基準 (De、Assunto、Data) に一致するレコードの存在をチェックします。 これにより、重複したエントリが防止されます。 効率を高めるために SELECT 1
を使用することに注意してください。すべての列を取得するのではなく、一致する行を 1 つ検索するだけで済みます。
この方法はほとんどのシナリオを効果的に処理しますが、同時実行性の高い環境では競合状態が発生する可能性があることを認識することが重要です。 絶対的なデータ整合性を確保するには、ストアド プロシージャ、トリガー、または適切なロック メカニズムなど、同時アクセスを管理してデータの不整合を防ぐ、より堅牢な手法を検討してください。
以上がSQL Server に一意のデータを挿入するときに「キーワード 'WHERE' 付近の構文が正しくありません」を回避するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。