ホームページ > データベース > mysql チュートリアル > SQL Server に一意のデータを挿入するときに「キーワード 'WHERE' 付近の構文が正しくありません」を回避するにはどうすればよいですか?

SQL Server に一意のデータを挿入するときに「キーワード 'WHERE' 付近の構文が正しくありません」を回避するにはどうすればよいですか?

Patricia Arquette
リリース: 2025-01-13 17:31:47
オリジナル
786 人が閲覧しました

How to Avoid

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 サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート