recherche
Maisondéveloppement back-endGolangComment puis-je insérer efficacement plusieurs lignes de données dans une base de données Go à l'aide d'instructions préparées ?

How Can I Efficiently Insert Multiple Rows of Data into a Go Database Using Prepared Statements?

Insertion efficace de plusieurs données dans Go

L'insertion de plusieurs lignes de données dans une base de données en une seule opération peut améliorer considérablement l'efficacité. Dans Go, une façon courante d'y parvenir consiste à utiliser des instructions préparées. Bien que l'utilisation de la concaténation de chaînes comme démontré dans votre question puisse sembler pratique, elle est moins sécurisée et peut conduire à des vulnérabilités d'injection SQL.

Utilisation d'instructions préparées

Pour insérer plusieurs lignes à l'aide déclarations préparées, vous pouvez suivre ces étapes :

  1. Créer un modèle d'instruction SQL avec des espaces réservés pour les données valeurs :
INSERT INTO test(n1, n2, n3) VALUES (?, ?, ?)
  1. Préparez l'instruction à l'aide de la méthode db.Prepare :
stmt, err := db.Prepare(sqlStr)
if err != nil {
    // Handle error
}
  1. Construisez une tranche de valeurs pour chaque ligne :
vals := []interface{}{}

for _, dataRow := range data {
    vals = append(vals, dataRow["v1"], dataRow["v2"], dataRow["v3"])
}
  1. Exécutez l'instruction avec le valeurs :
res, err := stmt.Exec(vals...)
if err != nil {
    // Handle error
}

Cette approche garantit que l'instruction SQL n'est analysée qu'une seule fois et que les valeurs sont insérées en toute sécurité en tant que paramètres.

Exemple :

Voici un exemple d'insertion de plusieurs lignes dans une table « test » à l'aide d'instructions préparées :

import (
    "database/sql"
    "fmt"
)

type DataRow struct {
    v1 string
    v2 string
    v3 string
}

func main() {
    data := []DataRow{
        {v1: "1", v2: "1", v3: "1"},
        {v1: "2", v2: "2", v3: "2"},
        {v1: "3", v2: "3", v3: "3"},
    }

    db, err := sql.Open("mysql", "user:password@tcp(localhost:3306)/database")
    if err != nil {
        // Handle error
    }

    sqlStr := "INSERT INTO test(n1, n2, n3) VALUES (?, ?, ?)"
    stmt, err := db.Prepare(sqlStr)
    if err != nil {
        // Handle error
    }

    vals := []interface{}{}
    for _, dataRow := range data {
        vals = append(vals, dataRow.v1, dataRow.v2, dataRow.v3)
    }

    res, err := stmt.Exec(vals...)
    if err != nil {
        // Handle error
    }

    affectedRows, err := res.RowsAffected()
    if err != nil {
        // Handle error
    }

    fmt.Printf("Inserted %d rows", affectedRows)
}

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
Comment parcourez-vous une carte en Go?Comment parcourez-vous une carte en Go?Apr 28, 2025 pm 05:15 PM

L'article discute de l'itération des cartes dans GO, en se concentrant sur des pratiques sûres, en modifiant les entrées et en considérations de performance pour les grandes cartes.

Comment créez-vous une carte dans Go?Comment créez-vous une carte dans Go?Apr 28, 2025 pm 05:14 PM

L'article discute de la création et de la manipulation de cartes dans GO, y compris des méthodes d'initialisation et de l'ajout / mise à jour des éléments.

Quelle est la différence entre un tableau et une tranche en Go?Quelle est la différence entre un tableau et une tranche en Go?Apr 28, 2025 pm 05:13 PM

L'article traite des différences entre les tableaux et les tranches dans GO, en se concentrant sur la taille, l'allocation de la mémoire, le passage des fonctions et les scénarios d'utilisation. Les tableaux sont de taille fixe, alloués par la pile, tandis que les tranches sont dynamiques, souvent allouées au tas et plus flexibles.

Comment créez-vous une tranche dans GO?Comment créez-vous une tranche dans GO?Apr 28, 2025 pm 05:12 PM

L'article discute de la création et de l'initialisation des tranches en Go, y compris l'utilisation des littéraux, la fonction de faire et de couper des tableaux ou des tranches existantes. Il couvre également la syntaxe de tranche et déterminant la longueur et la capacité des tranches.

Comment créez-vous un tableau dans Go?Comment créez-vous un tableau dans Go?Apr 28, 2025 pm 05:11 PM

L'article explique comment créer et initialiser les tableaux dans GO, discute des différences entre les tableaux et les tranches, et aborde la limite de taille maximale pour les tableaux. Arrays vs tranches: fixe vs dynamique, valeur par rapport aux types de référence.

Quelle est la syntaxe pour créer une structure en Go?Quelle est la syntaxe pour créer une structure en Go?Apr 28, 2025 pm 05:10 PM

L'article traite de la syntaxe et de l'initialisation des structures dans GO, y compris les règles de dénomination du champ et l'intégration des structures. Problème principal: comment utiliser efficacement les structures dans la programmation GO. (Caractères: 159)

Comment créez-vous un pointeur dans Go?Comment créez-vous un pointeur dans Go?Apr 28, 2025 pm 05:09 PM

L'article explique la création et l'utilisation de pointeurs en Go, en discutant des avantages tels que une utilisation efficace de la mémoire et des pratiques de gestion sûres. Problème principal: utilisation du pointeur sûr.

Quels sont les avantages d'utiliser GO?Quels sont les avantages d'utiliser GO?Apr 28, 2025 pm 05:08 PM

L'article traite des avantages de l'utilisation de Go (Golang) dans le développement de logiciels, en se concentrant sur son support concurrentiel, sa compilation rapide, sa simplicité et ses avantages d'évolutivité. Les principales industries bénéficiant comprennent la technologie, la finance et les jeux.

See all articles

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Version crackée d'EditPlus en chinois

Version crackée d'EditPlus en chinois

Petite taille, coloration syntaxique, ne prend pas en charge la fonction d'invite de code

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Télécharger la version Mac de l'éditeur Atom

Télécharger la version Mac de l'éditeur Atom

L'éditeur open source le plus populaire