Comment se connecter à une base de données SQL dans 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.
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.).

Voici comment le faire étape par étape:
✅ 1. Importez les packages requis
Vous avez besoin de deux choses:

- 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):

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"
(avecjackc/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é, utilisezdb.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!

Outils d'IA chauds

Undress AI Tool
Images de déshabillage gratuites

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

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

Clothoff.io
Dissolvant de vêtements AI

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 !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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

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

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

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

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

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.

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

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.

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.
