Maison développement back-end Golang Guide de connexion à la base de données Go Language : vous guide étape par étape pour effectuer les opérations de base de données

Guide de connexion à la base de données Go Language : vous guide étape par étape pour effectuer les opérations de base de données

Jan 23, 2024 am 08:33 AM
go语言 指南 数据库连接

Guide de connexion à la base de données Go Language : vous guide étape par étape pour effectuer les opérations de base de données

Le langage Go est un langage de programmation relativement convivial pour les débutants, concis, efficace et facile à apprendre. En tant que développeur, se connecter et utiliser des bases de données est une partie essentielle de notre travail quotidien. Dans cet article, je vais vous montrer comment vous connecter à une base de données en utilisant le langage Go et vous fournir quelques exemples de code spécifiques.

Tout d’abord, nous devons importer le pilote de base de données du langage Go. Actuellement, le langage Go prend en charge diverses bases de données, telles que MySQL, SQLite, PostgreSQL, etc. Vous pouvez choisir le pilote approprié en fonction de vos besoins. Dans cet article, nous prenons MySQL comme exemple.

Tout d'abord, nous devons importer le package de pilotes MySQL dans le projet de langage Go. Vous pouvez ajouter le code suivant au fichier go.mod :

require github.com/go-sql-driver/mysql v1.7.0
Copier après la connexion

Ensuite, nous pouvons établir une connexion avec la base de données MySQL via le code suivant :

import (
    "database/sql"
    _ "github.com/go-sql-driver/mysql"
)

func main() {
    // 数据库连接信息
    username := "root"
    password := "123456"
    host := "127.0.0.1"
    port := "3306"
    database := "example"
    
    // 建立数据库连接
    connectionString := fmt.Sprintf("%s:%s@tcp(%s:%s)/%s?charset=utf8&parseTime=True&loc=Local",
        username, password, host, port, database)
    db, err := sql.Open("mysql", connectionString)
    if err != nil {
        log.Fatal(err)
    }

    defer db.Close()
}
Copier après la connexion

Dans le code ci-dessus, nous utilisons la fonction database/sql包和github.com/go-sql-driver/mysql包。sql.Open()函数用于建立与MySQL数据库的连接,其中第一个参数是驱动名称,第二个参数是连接字符串。如果连接数据库时发生错误,我们将使用log.Fatal() pour imprimer les informations d'erreur et quitter le programme.

Une fois la connexion à la base de données établie avec succès, nous pouvons effectuer diverses opérations sur la base de données. Voici quelques exemples courants d'opérations de base de données :

  1. Requête de données :
rows, err := db.Query("SELECT * FROM users")
if err != nil {
    log.Fatal(err)
}
defer rows.Close()

for rows.Next() {
    var id int
    var name string
    err := rows.Scan(&id, &name)
    if err != nil {
        log.Fatal(err)
    }
    fmt.Println(id, name)
}
Copier après la connexion
  1. Insérer des données :
stmt, err := db.Prepare("INSERT INTO users (name) VALUES (?)")
if err != nil {
    log.Fatal(err)
}
defer stmt.Close()

res, err := stmt.Exec("John")
if err != nil {
    log.Fatal(err)
}

lastID, err := res.LastInsertId()
if err != nil {
    log.Fatal(err)
}
fmt.Println("Inserted ID:", lastID)
Copier après la connexion
  1. Mettre à jour les données :
stmt, err := db.Prepare("UPDATE users SET name = ? WHERE id = ?")
if err != nil {
    log.Fatal(err)
}
defer stmt.Close()

res, err := stmt.Exec("John Doe", 1)
if err != nil {
    log.Fatal(err)
}

affectedRows, err := res.RowsAffected()
if err != nil {
    log.Fatal(err)
}
fmt.Println("Affected Rows:", affectedRows)
Copier après la connexion
  1. Supprimer des données :
stmt, err := db.Prepare("DELETE FROM users WHERE id = ?")
if err != nil {
    log.Fatal(err)
}
defer stmt.Close()

res, err := stmt.Exec(1)
if err != nil {
    log.Fatal(err)
}

affectedRows, err := res.RowsAffected()
if err != nil {
    log.Fatal(err)
}
fmt.Println("Affected Rows:", affectedRows)
Copier après la connexion

Le code ci-dessus est simplement une base de données de base Exemple d'opération. Dans le développement réel, vous aurez peut-être besoin de requêtes et de traitements de transactions plus complexes. Cependant, grâce aux exemples ci-dessus, vous avez déjà compris comment utiliser le langage Go pour vous connecter à la base de données et effectuer certaines opérations courantes sur la base de données.

Pour résumer, cet article présente en détail comment utiliser le langage Go pour se connecter à la base de données MySQL et donne quelques exemples de code spécifiques. J'espère que cela vous aidera à vous connecter et à utiliser la base de données dans le développement du langage Go. Si vous avez des questions ou des confusions, vous pouvez laisser un message ci-dessous et je ferai de mon mieux pour y répondre. Je vous souhaite une bonne étude et écrivez du code en langage Go élégant et efficace !

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

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

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Repo: Comment relancer ses coéquipiers
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD

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)

Comment utiliser la réflexion pour accéder aux champs et méthodes privés dans Golang Comment utiliser la réflexion pour accéder aux champs et méthodes privés dans Golang May 03, 2024 pm 12:15 PM

Vous pouvez utiliser la réflexion pour accéder aux champs et méthodes privés en langage Go : Pour accéder aux champs privés : obtenez la valeur de réflexion de la valeur via Reflect.ValueOf(), puis utilisez FieldByName() pour obtenir la valeur de réflexion du champ, et appelez le Méthode String() pour imprimer la valeur du champ. Appelez une méthode privée : obtenez également la valeur de réflexion de la valeur via Reflect.ValueOf(), puis utilisez MethodByName() pour obtenir la valeur de réflexion de la méthode, et enfin appelez la méthode Call() pour exécuter la méthode. Cas pratique : modifiez les valeurs des champs privés et appelez des méthodes privées par réflexion pour obtenir le contrôle des objets et la couverture des tests unitaires.

La différence entre les tests de performances et les tests unitaires en langage Go La différence entre les tests de performances et les tests unitaires en langage Go May 08, 2024 pm 03:09 PM

Les tests de performances évaluent les performances d'une application sous différentes charges, tandis que les tests unitaires vérifient l'exactitude d'une seule unité de code. Les tests de performances se concentrent sur la mesure du temps de réponse et du débit, tandis que les tests unitaires se concentrent sur la sortie des fonctions et la couverture du code. Les tests de performances simulent des environnements réels avec une charge et une concurrence élevées, tandis que les tests unitaires s'exécutent dans des conditions de faible charge et en série. L'objectif des tests de performances est d'identifier les goulots d'étranglement des performances et d'optimiser l'application, tandis que l'objectif des tests unitaires est de garantir l'exactitude et la robustesse du code.

Connexions avancées aux bases de données PHP : transactions, verrous et contrôle de concurrence Connexions avancées aux bases de données PHP : transactions, verrous et contrôle de concurrence Jun 01, 2024 am 11:43 AM

Les connexions avancées aux bases de données PHP impliquent des transactions, des verrous et un contrôle de concurrence pour garantir l'intégrité des données et éviter les erreurs. Une transaction est une unité atomique d'un ensemble d'opérations, gérée via les méthodes beginTransaction(), commit() et rollback(). Les verrous empêchent l'accès simultané aux données via PDO::LOCK_SHARED et PDO::LOCK_EXCLUSIVE. Le contrôle d'accès concurrentiel coordonne l'accès à plusieurs transactions via les niveaux d'isolement MySQL (lecture non validée, lecture validée, lecture répétable, sérialisée). Dans les applications pratiques, les transactions, les verrous et le contrôle de concurrence sont utilisés pour la gestion des stocks de produits sur les sites Web d'achat afin de garantir l'intégrité des données et d'éviter les problèmes d'inventaire.

Pourquoi ma connexion à la base de données PHP échoue-t-elle ? Pourquoi ma connexion à la base de données PHP échoue-t-elle ? Jun 05, 2024 pm 07:55 PM

Les raisons d'un échec de connexion à la base de données PHP incluent : le serveur de base de données n'est pas en cours d'exécution, un nom d'hôte ou un port incorrect, des informations d'identification de base de données incorrectes ou un manque d'autorisations appropriées. Les solutions incluent : le démarrage du serveur, la vérification du nom d'hôte et du port, la vérification des informations d'identification, la modification des autorisations et l'ajustement des paramètres du pare-feu.

À quels pièges devons-nous prêter attention lors de la conception de systèmes distribués avec la technologie Golang ? À quels pièges devons-nous prêter attention lors de la conception de systèmes distribués avec la technologie Golang ? May 07, 2024 pm 12:39 PM

Pièges du langage Go lors de la conception de systèmes distribués Go est un langage populaire utilisé pour développer des systèmes distribués. Cependant, il existe certains pièges à prendre en compte lors de l'utilisation de Go qui peuvent nuire à la robustesse, aux performances et à l'exactitude de votre système. Cet article explorera quelques pièges courants et fournira des exemples pratiques sur la façon de les éviter. 1. Surutilisation de la concurrence Go est un langage de concurrence qui encourage les développeurs à utiliser des goroutines pour augmenter le parallélisme. Cependant, une utilisation excessive de la concurrence peut entraîner une instabilité du système, car trop de goroutines se disputent les ressources et entraînent une surcharge de changement de contexte. Cas pratique : une utilisation excessive de la concurrence entraîne des retards de réponse des services et une concurrence entre les ressources, qui se manifestent par une utilisation élevée du processeur et une surcharge importante de garbage collection.

Bibliothèques technologiques Golang et outils utilisés dans l'apprentissage automatique Bibliothèques technologiques Golang et outils utilisés dans l'apprentissage automatique May 08, 2024 pm 09:42 PM

Les bibliothèques et outils d'apprentissage automatique dans le langage Go incluent : TensorFlow : une bibliothèque d'apprentissage automatique populaire qui fournit des outils pour créer, entraîner et déployer des modèles. GoLearn : Une série d'algorithmes de classification, de régression et de clustering. Gonum : Une bibliothèque de calcul scientifique qui fournit des opérations matricielles et des fonctions d'algèbre linéaire.

L'évolution de la convention de dénomination des fonctions Golang L'évolution de la convention de dénomination des fonctions Golang May 01, 2024 pm 03:24 PM

L'évolution de la convention de dénomination des fonctions Golang est la suivante : Début (Go1.0) : il n'y a pas de convention formelle et la dénomination des chameaux est utilisée. Convention de soulignement (Go1.5) : les fonctions exportées commencent par une lettre majuscule et sont préfixées par un trait de soulignement. Convention des fonctions d'usine (Go1.13) : les fonctions qui créent de nouveaux objets sont représentées par le préfixe « Nouveau ».

Le rôle de la technologie Golang dans le développement de l'IoT mobile Le rôle de la technologie Golang dans le développement de l'IoT mobile May 09, 2024 pm 03:51 PM

Grâce à sa haute concurrence, son efficacité et sa nature multiplateforme, le langage Go est devenu un choix idéal pour le développement d'applications mobiles pour l'Internet des objets (IoT). Le modèle de concurrence de Go atteint un degré élevé de concurrence grâce aux goroutines (coroutines légères), ce qui convient à la gestion d'un grand nombre d'appareils IoT connectés en même temps. La faible consommation de ressources de Go permet d'exécuter efficacement des applications sur des appareils mobiles avec des ressources informatiques et un stockage limités. De plus, la prise en charge multiplateforme de Go permet aux applications IoT d’être facilement déployées sur une variété d’appareils mobiles. Le cas pratique montre l'utilisation de Go pour créer une application de capteur de température BLE, communiquant avec le capteur via BLE et traitant les données entrantes pour lire et afficher les relevés de température.

See all articles