Table des matières
✅ 1. Importez les packages requis
✅ 2. Ouvrez une connexion à la base de données
✅ 3. Effectuez des requêtes
✅ 4. Utiliser la regroupement de connexion (facultatif mais recommandé)
Exemple de travail complet (MySQL)
Résumé
Maison développement back-end Golang Comment se connecter à une base de données SQL dans Go?

Comment se connecter à une base de données SQL dans Go?

Aug 03, 2025 am 09:31 AM
go

Pour vous connecter aux bases de données SQL dans GO, vous devez utiliser le package de base de données / SQL et un pilote de base de données spécifique. 1. Importez des packages et des pilotes de base de données / SQL (tels que github.com/go-sql-driver/mysql), et notez que cela souligne avant que le pilote signifie qu'il n'est utilisé que pour l'initialisation; 2. Utilisez sql.open ("mysql", "utilisateur: mot de passe @ tcp (localhost: 3306) / dbname") pour créer une poignée de base de données et appeler db.ping () pour vérifier la connexion; 3. Utilisez db.query () pour exécuter Query, db.exec () pour effectuer l'insertion, mettre à jour ou supprimer, et lire les résultats via des lignes.scan (), et faire attention à vérifier les lignes.err (); 4. Vous pouvez configurer des paramètres de pool de connexion tels que db.setMaxOpenConns (25) pour optimiser les performances. L'exemple complet comprend l'importation, la connexion, la requête et la version des ressources, garantissant que les erreurs sont gérées à chaque étape et, finalement, connecter et utiliser la base de données.

Comment se connecter à une base de données SQL dans Go?

La connexion à une base de données SQL dans GO est simple à l'aide du package database/sql , qui fournit une interface générique pour les bases de données SQL, ainsi qu'un pilote spécifique à la base de données que vous utilisez (comme MySQL, PostgreSQL, SQLite, etc.).

Comment se connecter à une base de données SQL dans Go?

Voici comment le faire étape par étape:


✅ 1. Importez les packages requis

Vous avez besoin de deux choses:

Comment se connecter à une base de données SQL dans Go?
  • Le package database/sql (bibliothèque GO standard)
  • Un pilote pour votre base de données spécifique

Par exemple, si vous utilisez PostgreSQL , vous pouvez utiliser lib/pq ou jackc/pgx ; Pour MySQL , go-sql-driver/mysql ; Pour SQLite , mattn/go-sqlite3 .

Installez le pilote via go.mod (exemple pour mysql):

Comment se connecter à une base de données SQL dans Go?
 Allez obtenir github.com/go-sql-driver/mysql

Puis importez dans votre code:

 importer (
    "base de données / SQL"
    "FMT"
    _ "github.com/go-sql-driver/mysql" // Importer le pilote (Remarque le soulignement)
)

? Le _ signifie que nous l'importons pour ses effets secondaires (initialisation du pilote), pas pour l'utiliser directement.


✅ 2. Ouvrez une connexion à la base de données

Utilisez sql.Open() pour créer une poignée de base de données. Il ne se connecte pas immédiatement mais initialise les informations de connexion.

 db, err: = sql.open ("mysql", "utilisateur: mot de passe @ tcp (localhost: 3306) / dbname")
Si err! = Nil {
    panique (euh)
}
différer db.close () // assurez-vous de fermer lorsque vous avez terminé

Remplacez la chaîne de connexion en fonction de votre base de données:

  • MySQL : "user:pass@tcp(localhost:3306)/mydb"
  • PostgreSQL : "host=localhost user=usr password=pass dbname=mydb sslmode=disable" (avec jackc/pgx )
  • Sqlite : "file:mydb.sqlite"

⚠️ sql.Open() peut ne pas renvoyer une erreur même si le DSN est faux - il prépare simplement la connexion. Pour tester la connectivité, utilisez db.Ping() .

 err = db.ping ()
Si err! = Nil {
    panique ("Impossible de se connecter à la base de données:" err.Error ())
}

✅ 3. Effectuez des requêtes

Une fois connecté, vous pouvez exécuter des requêtes:

 lignes, err: = db.query ("SELECT ID, nom dans les utilisateurs")
Si err! = Nil {
    panique (euh)
}
déférer des lignes.close ()

pour rows.next () {
    var id int
    chaîne de nom var
    err: = rows.scan (& id, & name)
    Si err! = Nil {
        panique (euh)
    }
    fmt.printf ("id:% d, nom:% s \ n", id, nom)
}

// Vérifiez les erreurs après itération
si err = lignes.err (); err! = Nil {
    panique (euh)
}

Utilisez db.Exec() pour insérer, mettre à jour, supprimer:

 Résultat, err: = db.exec ("Insérer dans les valeurs des utilisateurs (nom) (?)", "Alice")
Si err! = Nil {
    panique (euh)
}

LASTID, ERR: = result.LastInsertid ()
Si err! = Nil {
    panique (euh)
}
fmt.printf ("Dernier ID inséré:% d \ n", Lastid)

✅ 4. Utiliser la regroupement de connexion (facultatif mais recommandé)

sql.DB de Go est conçu pour être à longue durée de vie et gère automatiquement la mise en commun des connexions.

Vous pouvez le régler:

 db.setMaxOpennns (25)
db.setMaxidleConns (5)
db.setConnmaxlifetime (5 * time.Minute)

Cela permet d'éviter l'épuisement des ressources dans la production.


Exemple de travail complet (MySQL)

 package principal

importer (
    "base de données / SQL"
    "FMT"
    "enregistrer"
    _ "github.com/go-sql-driver/mysql"
)

func main () {
    db, err: = sql.open ("mysql", "root: mot de passe @ tcp (127.0.0.1:3306) / testdb")
    Si err! = Nil {
        log.fatal (err)
    }
    différer db.close ()

    err = db.ping ()
    Si err! = Nil {
        Log.Fatal ("Échec de la base de données Ping:", ERR)
    }

    chaîne de version var
    err = db.queryRow ("SELECT VERSION ()"). Scan (& Version)
    Si err! = Nil {
        log.fatal (err)
    }

    fmt.println ("Version de la base de données:", version)
}

Résumé

  • Utilisez database/sql un pilote
  • Appelez sql.Open() avec DSN correct
  • Toujours db.Ping() pour vérifier la connexion
  • Utilisez Query , Exec , QueryRow pour les opérations
  • Laisse aller gérer les connexions via la mise en commun

Ce n'est pas complexe, mais facile de gâcher le formatage DSN ou d'oublier des vérifications d'erreur après rows.Next() .

Fondamentalement, c'est tout ce dont vous avez besoin pour commencer à vous connecter à une base de données SQL.

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 de ce site Web
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

Outils d'IA chauds

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

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.

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

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

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

Sujets chauds

Tutoriel PHP
1535
276
Comment fermer gracieusement un service GO? Comment fermer gracieusement un service GO? Aug 05, 2025 pm 08:21 PM

Usesignal.notify () TolistenForsigint / SigterandTriggersHutdown; 2.RunthehttpServerinagoroutineandblockuntilasignalisreceived; 3.CallServer.Shutdown () avec un aontextTimeoutTostopaccepingEptureNewrequestSallowine-FLIMESTOSTOCLEM

Comment obtenir l'heure actuelle en Go Comment obtenir l'heure actuelle en Go Aug 06, 2025 am 11:28 AM

UseTime.now () togetTheCurrentLocaltimeAsatime.TimeObject; 2.FormatTheTimeusingtheformatmethodwithlayoutslik "2006-01-0215: 04: 05"; 3.GetUtCtimeByCallingUtc () onTheResultime.now (); 4.xtractconntslikeliseyyar, mois, DayUsiTheThoDs

Comment analyser les données XML dans Go Comment analyser les données XML dans Go Aug 05, 2025 pm 07:24 PM

Les données XML d'analyse sont très simples en Go, utilisez simplement le package d'encodage / XML intégré. 1. Définissez une structure avec la balise XML pour mapper des éléments et des attributs XML, tels que XML: "Nom" Eléments enfants correspondants, XML: "Contact> Email" Père la nidification, XML: "ID, AttR" lit Attributs; 2. Utilisez XML.unmarshal pour analyser les chaînes XML en structures; 3. Pour les fichiers, utilisez OS.Open pour les ouvrir et les décoder via XML.NewDecoder, qui convient au traitement en streaming des fichiers volumineux; 4. Lors du traitement des éléments en double, dans la structure

Comment transformez-vous une application GO? Comment transformez-vous une application GO? Aug 06, 2025 am 05:52 AM

Cross-compilingaGoapplicationisstraightforwardusingbuilt-insupportviaGOOSandGOARCH.1.SetGOOSforthetargetoperatingsystem(e.g.,linux,windows,darwin).2.SetGOARCHforthetargetarchitecture(e.g.,amd64,arm64).3.Rungobuildwiththesevariables,suchasGOOS=linuxGO

Comment créer et utiliser des types d'erreur personnalisés dans Go Comment créer et utiliser des types d'erreur personnalisés dans Go Aug 11, 2025 pm 11:08 PM

Dans GO, la création et l'utilisation de types d'erreurs personnalisés peuvent améliorer l'expressivité et la débogabilité de la gestion des erreurs. La réponse est de créer une erreur personnalisée en définissant une structure qui implémente la méthode Error (). Par exemple, ValidationError contient des champs de champ et de messages et renvoie les informations d'erreur formatées. L'erreur peut ensuite être renvoyée dans la fonction, détectant des types d'erreur spécifiques via des assertions ou des erreurs de type. Vous pouvez également ajouter des méthodes comportementales telles que les erreurs ISCRITIQUES à personnalisées, qui conviennent aux scénarios qui nécessitent des données structurées, un traitement différencié, une exportation de bibliothèque ou une intégration API. Dans des cas simples, des erreurs.

Comment utiliser le chemin / le fil de file pour la manipulation de chemin multiplateforme en go Comment utiliser le chemin / le fil de file pour la manipulation de chemin multiplateforme en go Aug 08, 2025 pm 05:29 PM

UseFilepath.join () tosafelyconstructPathswithcorrectos-spécifications ..2.UseFilePath.clean () toreMoverEdundantelements like ".." et ".". 3.UseFilepath.split () toseParateDirectoryandFileComponents.4.UseFilePath.Dir (), FilePath.base (), an

Comment gérer les paniques et récupérer Comment gérer les paniques et récupérer Aug 06, 2025 pm 02:08 PM

La fonction de récupération doit être appelée en report pour capturer la panique; 2. Utilisez la récupération dans des programmes de longue durée tels que Goroutine ou Server pour empêcher l'ensemble du programme de se bloquer; 3. La récupération ne doit pas être abusée, uniquement utilisée lorsqu'elle est manipulée, pour éviter de remplacer la gestion des erreurs normale; 4. Les meilleures pratiques incluent l'enregistrement des informations de panique, en utilisant Debug.stack () pour obtenir des traces de pile et récupérer à un niveau approprié. La récupération n'est valable que dans le report et doit être utilisée pour le débogage avec des journaux. Les bogues potentiels ne peuvent pas être ignorés. En fin de compte, le code doit être conçu en renvoyant l'erreur plutôt qu'en panique.

Comment gérez-vous les signaux dans une application Go? Comment gérez-vous les signaux dans une application Go? Aug 11, 2025 pm 08:01 PM

La bonne façon de traiter les signaux dans les applications GO consiste à utiliser le package OS / Signal pour surveiller le signal et effectuer un arrêt élégant. 1. Utilisez Signal.Notify pour envoyer SIGINT, SIGTERM et d'autres signaux au canal; 2. Exécutez le service principal en goroutine et bloquez le signal d'attente; 3. Après avoir reçu le signal, effectuez un arrêt élégant avec le délai d'expiration via Context.withTimeout; 4. Nettoyer des ressources telles que la fermeture des connexions de la base de données et l'arrêt de la goroutine d'arrière-plan; 5. Utilisez le signal.Resine pour restaurer le comportement du signal par défaut lorsque cela est nécessaire pour vous assurer que le programme peut être terminé de manière fiable en Kubernetes et dans d'autres environnements.

See all articles