ホームページ >バックエンド開発 >Golang >単一のクエリを使用して PostgreSQL の複数の行を効率的に一括更新するにはどうすればよいですか?

単一のクエリを使用して PostgreSQL の複数の行を効率的に一括更新するにはどうすればよいですか?

Mary-Kate Olsen
Mary-Kate Olsenオリジナル
2024-12-05 14:24:11181ブラウズ

How Can I Efficiently Bulk Update Multiple Rows in PostgreSQL Using a Single Query?

単一の PostgreSQL クエリによる複数の行の一括更新

Go を使用した PostgreSQL データベース内の複数の行の更新は、単一の SQL で効率的に実行できます声明。このアプローチは、複数のレコードを一度に更新する便利な方法を提供し、必要なクエリの数を減らし、パフォーマンスを向上させます。

一括更新を実行するには、派生テーブルを利用できます。これは、クエリの範囲。これにより、更新する行の値を指定できるようになります。その方法は次のとおりです。

UPDATE t
SET column_a = v.column_a,
    column_b = v.column_b
FROM (VALUES (1, 'FINISH', 1234),
             (2, 'UNFINISH', 3124)
     ) v(id, column_a, column_b)
WHERE v.id = t.id;

この例では、id、column_a、column_b の 3 つの列を持つ v という名前の派生テーブルを作成します。必要な更新を表す 2 つの行の値を提供します。 WHERE 句は、派生テーブルの ID 列を、更新するテーブル (t) の ID 列と照合します。

このアプローチでは、行を追加するだけで、更新する行を簡単に追加できます。派生テーブル。これは、複数の個別の更新ステートメントを作成する場合に比べて、エラーが発生しにくくなります。

以上が単一のクエリを使用して PostgreSQL の複数の行を効率的に一括更新するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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