ホームページ > バックエンド開発 > Golang > 派生テーブルを使用して PostgreSQL で一括行更新を効率的に実行するにはどうすればよいですか?

派生テーブルを使用して PostgreSQL で一括行更新を効率的に実行するにはどうすればよいですか?

DDD
リリース: 2024-12-09 20:27:19
オリジナル
1005 人が閲覧しました

How Can I Efficiently Perform Bulk Row Updates in PostgreSQL Using Derived Tables?

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.")
}
ログイン後にコピー

派生テーブルの利点アプローチ

  • 柔軟性: プライマリ クエリを変更せずに、行と列を更新に簡単に追加または削除します。
  • シンプルさ: 派生テーブルのアプローチは比較的理解しやすく、 implement.
  • 効率: 多数の行を更新する必要があるシナリオで良好なパフォーマンスを発揮します。

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

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート