PostgreSQL での効率的な一括行更新
単一のクエリで複数の行を一括更新することは、データベースのパフォーマンスを向上させるために使用される一般的な最適化です。 PostgreSQL は、このプロセスを容易にする強力なメカニズムを提供します。
派生テーブルのアプローチ
PostgreSQL での一括更新の効果的なアプローチの 1 つは、派生テーブルを利用することです。このアプローチには、必要な更新を含む一時テーブルを作成し、それを使用してターゲット テーブルを変更することが含まれます。
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;
このクエリは、特定の行更新を含む派生テーブル v を作成します。 UPDATE ステートメントは、このテーブルを使用して t テーブルを変更します。 WHERE 句により、更新が正しい行にのみ適用されるようになります。
Go 言語の例
Go でこのクエリを実行するには、次のコード スニペットを使用できます。 :
import ( "context" "database/sql" "fmt" ) func main() { db, err := sql.Open("postgres", "host=localhost user=postgres password=password dbname=postgres sslmode=disable") if err != nil { panic(err) } ctx := context.Background() query := ` 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; ` _, err = db.ExecContext(ctx, query) if err != nil { panic(err) } fmt.Println("Rows updated successfully.") }
派生テーブルの利点アプローチ
以上が派生テーブルを使用して PostgreSQL で一括行更新を効率的に実行するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。