recherche
Maisondéveloppement back-endGolangLorsque vous utilisez SQL.Open, pourquoi ne signale pas une erreur lorsque DSN passe vide?

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!

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
GO TANCER ERREUR: meilleures pratiques et modèlesGO TANCER ERREUR: meilleures pratiques et modèlesMay 04, 2025 am 12:19 AM

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.

Comment implémentez-vous la concurrence dans GO?Comment implémentez-vous la concurrence dans GO?May 04, 2025 am 12:13 AM

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.

Construire des structures de données simultanées en GoConstruire des structures de données simultanées en GoMay 04, 2025 am 12:09 AM

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

Comparaison de la gestion des erreurs de Go à d'autres langages de programmationComparaison de la gestion des erreurs de Go à d'autres langages de programmationMay 04, 2025 am 12:09 AM

Go'SerrorHandlinlingexplicit, traitantaRrorsaSreturnedValuesRatherThanExceptions, contrairement

Tester le code qui repose sur les fonctions d'initiés dans GoTester le code qui repose sur les fonctions d'initiés dans GoMay 03, 2025 am 12:20 AM

WHORSTINGGOCODEWITHINITFONCTIONS, USEZPLICITSETUPFUNCTIONSORSORSPARATETESTFILESTOAVOIDDEPENDENCYONINITFUNCTIONSIDEFFECTS.1) USEZPLICITSEUPFUNCTIONSTOCONTROLGLOBALVARIABIABLE INTIALISATION.2)

Comparaison de l'approche de gestion des erreurs de Go à d'autres languesComparaison de l'approche de gestion des erreurs de Go à d'autres languesMay 03, 2025 am 12:20 AM

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

Meilleures pratiques pour concevoir des interfaces efficaces dans GoMeilleures pratiques pour concevoir des interfaces efficaces dans GoMay 03, 2025 am 12:18 AM

ANEFFICECTERACEINGOISMIMIMAL, CARY et PROMOTESLOOSECOUPLING.1) MINIMIZETHEITERFACEFLAXEBIBILITÉ ENFICATION

Stratégies de gestion des erreurs centralisées en GoStratégies de gestion des erreurs centralisées en GoMay 03, 2025 am 12:17 AM

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.

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

SublimeText3 Linux nouvelle version

SublimeText3 Linux nouvelle version

Dernière version de SublimeText3 Linux

mPDF

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

SublimeText3 version Mac

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

Dreamweaver Mac

Dreamweaver Mac

Outils de développement Web visuel