


Lorsque vous utilisez SQL.Open, pourquoi ne signale pas une erreur lorsque DSN passe vide?
GO Language sql.Open
Fonction: la raison et la solution pour que le DSN vide ne signale aucune erreur
Dans le langage Go, la fonction sql.Open
est utilisée pour créer des connexions de base de données. Cependant, lorsque le nom de la source de données (DSN) est vide, sql.Open
ne rapporte pas une erreur, ce qui est souvent déroutant. Cet article expliquera ses raisons et fournira des solutions.
Description du problème
L'extrait de code suivant démontre le problème:
package principal importer ( "base de données / SQL" "FMT" _ "github.com/go-sql-driver/mysql" // Importer le pilote mysql) func main () { db, err: = sql.open ("mysql", "") fmt.println (err) // Le résultat de sortie est nul // ... Code ultérieur ... Une erreur sera signalée lorsque vous essayez d'utiliser DB}
Même si DSN est vide, sql.Open
renvoie toujours nil
Error, ce qui n'est pas le comportement attendu.
Analyse des problèmes
La fonction principale de la fonction sql.Open
est d'initialiser le pilote de base de données et de renvoyer un objet *sql.DB
Il n'essaie pas immédiatement de se connecter à la base de données, ni ne vérifie la validité du DSN. Ce n'est que lorsqu'une opération de base de données (telle que db.Query
ou db.Exec
) est effectuée, la connexion est réellement établie et validée.
Par conséquent, lorsque DSN est vide, sql.Open
ne signale pas d'erreur car il n'a pas tenté d'établir de connexion à la base de données. L'erreur n'apparaîtra pas lorsque l'objet *sql.DB
sera ensuite utilisé.
Solution
Afin de détecter la validité de DSN immédiatement après sql.Open
, il est recommandé d'utiliser db.Ping()
:
package principal importer ( "base de données / SQL" "FMT" _ "github.com/go-sql-driver/mysql" ) func main () { db, err: = sql.open ("mysql", "") Si err! = Nil { FMT.println ("SQL.Open Erreur:", ERR) Retour } différer db.close () err = db.ping () Si err! = Nil { fmt.println ("Db.ping Error:", err) Retour } fmt.println ("Connexion de base de données réussie!") // ... code d'enquête ... }
db.Ping()
essaie d'établir une connexion simple avec la base de données et renvoie toutes les erreurs de connexion. En ajoutant db.Ping()
, vous pouvez détecter tôt les erreurs de configuration DSN. N'oubliez pas d'appeler db.Close()
après utilisation pour fermer la connexion de la base de données.
Grâce aux améliorations ci-dessus, les erreurs de retard causées par le DSN vide peuvent être effectivement évitées et la robustesse et la maintenabilité du code peuvent être améliorées.
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!

Dans la programmation GO, les moyens de gérer efficacement les erreurs incluent: 1) en utilisant des valeurs d'erreur au lieu d'exceptions, 2) en utilisant des techniques d'emballage des erreurs, 3) la définition des types d'erreur personnalisés, 4) Réutiliser les valeurs d'erreur pour les performances, 5) en utilisant la panique et la récupération avec prudence, 6) assurer que les messages d'erreur sont clairs et cohérents, 7) enregistrer les stratégies d'erreur d'enregistrement, traitant les erreurs de première classe Citizens, 9). Ces pratiques et modèles aident à écrire un code plus robuste, maintenable et efficace.

La mise en œuvre de la concurrence dans GO peut être obtenue en utilisant des goroutines et des canaux. 1) Utilisez des goroutines pour effectuer des tâches en parallèle, comme profiter de la musique et observer des amis en même temps dans l'exemple. 2) Transférer solidement les données entre les goroutines via des canaux, tels que les modèles producteurs et consommateurs. 3) Évitez l'utilisation excessive des goroutines et des impasses et concevez le système raisonnablement pour optimiser les programmes simultanés.

GooffersMultipleAPPROYSFORBULDINGSCURRENTDATASTASTRUCTURES, notamment desMutexes, des canaux et des données.1)

Go'SerrorHandlinlingexplicit, traitantaRrorsaSreturnedValuesRatherThanExceptions, contrairement

WHORSTINGGOCODEWITHINITFONCTIONS, USEZPLICITSETUPFUNCTIONSORSORSPARATETESTFILESTOAVOIDDEPENDENCYONINITFUNCTIONSIDEFFECTS.1) USEZPLICITSEUPFUNCTIONSTOCONTROLGLOBALVARIABIABLE INTIALISATION.2)

Go'SerrorHandlingReturnSerRorSasValues, contrairement à javaandpythonwhichuseexception.1) Go'smethodensuresexpliciterrorHandling, PromotingRobustCodeButincreingverbosity.2)

ANEFFICECTERACEINGOISMIMIMAL, CARY et PROMOTESLOOSECOUPLING.1) MINIMIZETHEITERFACEFLAXEBIBILITÉ ENFICATION

Le traitement des erreurs centralisés peut améliorer la lisibilité et la maintenabilité du code dans le langage Go. Ses méthodes et avantages d'implémentation incluent: 1. Séparer la logique de gestion des erreurs de la logique métier et simplifier le code. 2. Assurer la cohérence de la gestion des erreurs par manipulation centrale. 3. Utilisez un report et récupérer pour capturer et traiter les paniques pour améliorer la robustesse du programme.


Outils d'IA chauds

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.

Undress AI Tool
Images de déshabillage gratuites

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

Version crackée d'EditPlus en chinois
Petite taille, coloration syntaxique, ne prend pas en charge la fonction d'invite de code

SublimeText3 Linux nouvelle version
Dernière version de SublimeText3 Linux

mPDF
mPDF est une bibliothèque PHP qui peut générer des fichiers PDF à partir de HTML encodé en UTF-8. L'auteur original, Ian Back, a écrit mPDF pour générer des fichiers PDF « à la volée » depuis son site Web et gérer différentes langues. Il est plus lent et produit des fichiers plus volumineux lors de l'utilisation de polices Unicode que les scripts originaux comme HTML2FPDF, mais prend en charge les styles CSS, etc. et présente de nombreuses améliorations. Prend en charge presque toutes les langues, y compris RTL (arabe et hébreu) et CJK (chinois, japonais et coréen). Prend en charge les éléments imbriqués au niveau du bloc (tels que P, DIV),

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

Dreamweaver Mac
Outils de développement Web visuel
