Maison >développement back-end >Golang >Comment puis-je effectuer efficacement des mises à jour groupées de lignes dans PostgreSQL à l'aide de tables dérivées ?

Comment puis-je effectuer efficacement des mises à jour groupées de lignes dans PostgreSQL à l'aide de tables dérivées ?

DDD
DDDoriginal
2024-12-09 20:27:191001parcourir

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

Mises à jour groupées efficaces des lignes dans PostgreSQL

La mise à jour groupée de plusieurs lignes dans une seule requête est une optimisation courante utilisée pour améliorer les performances de la base de données. PostgreSQL fournit des mécanismes puissants pour faciliter ce processus.

Approche de table dérivée

Une approche efficace pour les mises à jour groupées dans PostgreSQL consiste à utiliser une table dérivée. Cette approche consiste à créer une table temporaire avec les mises à jour souhaitées, puis à l'utiliser pour modifier la table cible.

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;

Cette requête crée une table dérivée v avec les mises à jour de lignes spécifiques. L'instruction UPDATE utilise ensuite cette table pour modifier la table t. La clause WHERE garantit que les mises à jour sont appliquées uniquement aux lignes correctes.

Exemple de langage Go

Pour exécuter cette requête dans Go, vous pouvez utiliser l'extrait de code suivant :

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.")
}

Avantages de la table dérivée Approche

  • Flexibilité :Ajoutez ou supprimez facilement des lignes et des colonnes à la mise à jour sans modifier la requête principale.
  • Simplicité : L'approche des tables dérivées est relativement simple à comprendre et mettre en œuvre.
  • Efficacité : Il fonctionne bien dans les scénarios où un grand nombre de lignes doivent être mises à jour.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn