ホームページ >データベース >mysql チュートリアル >UPDATE と LEFT JOIN を使用して Microsoft Access でアップサートをシミュレートする方法
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 サイトの他の関連記事を参照してください。