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