ホームページ >データベース >mysql チュートリアル >UPDATE と LEFT JOIN を使用して Microsoft Access でアップサートをシミュレートする方法

UPDATE と LEFT JOIN を使用して Microsoft Access でアップサートをシミュレートする方法

Linda Hamilton
Linda Hamiltonオリジナル
2025-01-19 20:12:09597ブラウズ

How to Simulate an Upsert in Microsoft Access Using UPDATE and LEFT JOIN?

Microsoft Access での挿入または更新 (アップサート)

質問:

Microsoft Access 2000 で、行が存在する場合は更新し、存在しない場合は新しい行を挿入する操作を実行したいと考えています。

解決策:

UPDATE と LEFT JOIN を使用して Upsert をシミュレートします

Access では、LEFT JOIN を含む UPDATE クエリを使用して更新/挿入をシミュレートできます。クエリは LEFT JOIN を使用して既存の行があるかどうかを確認し、それに応じて更新または挿入します。

<code class="language-sql">UPDATE b
LEFT JOIN a ON b.id = a.id
SET a.f1 = b.f1,
    a.f2 = b.f2,
    a.f3 = b.f3;</code>
このクエリでは、「b」は新しいデータを表し、「a」は既存のテーブルを表します。 "a" に一致する行がある場合、クエリは "a" の値を "b" の対応する値で更新します。それ以外の場合、クエリは「b」の値を使用して新しい行を「a」に挿入します。

簡略化された例:

わかりやすくするために、クエリの簡略化したバージョンを次に示します。

<code class="language-sql">UPDATE main_table RIGHT JOIN new_data 
    ON main_table.id = new_data.id
SET
    main_table.id = new_data.id,
    main_table.col_1 = new_data.col_1,
    main_table.col_2 = new_data.col_2;</code>
このクエリは、「new_data」の値に基づいて「main_table」の行を更新または挿入します。 「id」列が一致条件で、更新または挿入される値は「col_1」と「col_2」です。

以上がUPDATE と LEFT JOIN を使用して Microsoft Access でアップサートをシミュレートする方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。