Maison  >  Article  >  développement back-end  >  Parlons des différentes façons de sauvegarder des données à l'aide de Golang

Parlons des différentes façons de sauvegarder des données à l'aide de Golang

PHPz
PHPzoriginal
2023-04-03 09:19:12953parcourir

Avec la popularité croissante du langage Go, de nombreux développeurs utilisent Golang pour le développement de projets. L'une des questions importantes est de savoir comment sauvegarder les données. Dans cet article, nous aborderons différentes manières de sauvegarder des données à l'aide de Golang.

  1. Utilisation de JSON

JSON est un format léger pour l'échange de données. Dans Golang, nous pouvons utiliser le package encoding/json pour encoder les données d'une structure en données au format JSON. Nous pouvons également utiliser la méthode json.Unmarshal() pour décoder JSON en une structure Go. encoding/json包来从结构中将数据编码为JSON格式的数据。我们也可以使用json.Unmarshal()方法将JSON解码为一个Go结构。

例如,让我们创建一个结构体并将它编码为JSON:

type Person struct {
    Name string `json:"name"`
    Age  int    `json:"age"`
}

func main() {
    person := Person{Name: "Jack", Age: 25}

    jsonPerson, _ := json.Marshal(person)

    fmt.Println(string(jsonPerson))
}

输出:

{"name":"Jack","age":25}

我们还可以使用json.Unmarshal()方法将JSON解码为结构体:

jsonString := `{"name":"Jack","age":25}`

person := Person{}
json.Unmarshal([]byte(jsonString), &person)

fmt.Printf("Name: %s, Age: %d", person.Name, person.Age)

输出:

Name: Jack, Age: 25
  1. 使用SQL数据库

Golang的标准库中有一个database/sql包,可以用于访问SQL数据库。我们可以使用这个包来保存和检索数据。

比如,我们可以连接到MySQL数据库,并保存一个人的数据:

db, _ := sql.Open("mysql", "user:password@tcp(127.0.0.1:3306)/database")
defer db.Close()

sqlInsert := `INSERT INTO people (name, age) VALUES (?, ?)`
stmt, _ := db.Prepare(sqlInsert)
defer stmt.Close()

res, _ := stmt.Exec("Jack", 25)
id, _ := res.LastInsertId()

fmt.Println("Inserted a new person with ID:", id)

上面的代码将一个人的数据添加到了MySQL数据库中。

我们还可以使用database/sql包来检索数据。以下是从数据库中检索数据的示例:

rows, _ := db.Query("SELECT * FROM people")

var name string
var age int

for rows.Next() {
    rows.Scan(&id, &name, &age)

    fmt.Printf("ID: %d, Name: %s, Age: %d\n", id, name, age)
}

上述代码将检索所有人的数据并将其打印在控制台上。

  1. 使用NoSQL数据库

与SQL数据库不同,NoSQL数据库更适合非结构化的数据。Golang中最流行的NoSQL数据库之一是MongoDB。我们可以使用mgo

Par exemple, créons une structure et encodons-la en JSON :

session, _ := mgo.Dial("mongodb://localhost:27017")
defer session.Close()

c := session.DB("mydb").C("people")

err := c.Insert(&Person{Name: "Jack", Age: 25})
if err != nil {
    log.Fatal(err)
}
Sortie :

results := []Person{}
err := c.Find(bson.M{}).All(&results)
if err != nil {
    log.Fatal(err)
}

for _, person := range results {
    fmt.Printf("Name: %s, Age: %d\n", person.Name, person.Age)
}
Nous pouvons également utiliser la méthode json.Unmarshal() pour décoder JSON en une struct :

rrreee

Sortie :

rrreee

    Utilisation de la base de données SQL

    La bibliothèque standard de Golang possède un package database/sql qui peut être utilisé pour accéder aux bases de données SQL. Nous pouvons utiliser ce package pour enregistrer et récupérer des données.

    🎜Par exemple, nous pouvons nous connecter à la base de données MySQL et enregistrer les données d'une personne : 🎜rrreee🎜Le code ci-dessus ajoute les données d'une personne à la base de données MySQL. 🎜🎜Nous pouvons également utiliser le package database/sql pour récupérer des données. Voici un exemple de récupération de données de la base de données : 🎜rrreee🎜Le code ci-dessus récupérera les données de chacun et les imprimera sur la console. 🎜
      🎜Utiliser la base de données NoSQL🎜🎜🎜Contrairement à la base de données SQL, la base de données NoSQL est plus adaptée aux données non structurées. L'une des bases de données NoSQL les plus populaires de Golang est MongoDB. Nous pouvons utiliser le package mgo pour nous connecter à MongoDB et enregistrer et récupérer des données. 🎜🎜Ce qui suit est un exemple d'enregistrement des données d'une personne dans MongoDB : 🎜rrreee🎜Le code ci-dessus ajoute les données d'une personne à la base de données MongoDB. 🎜🎜Voici un exemple de récupération de données depuis MongoDB : 🎜rrreee🎜Le code ci-dessus récupérera les données de chacun et les imprimera sur la console. 🎜🎜Résumé🎜🎜Cet article a présenté différentes manières de sauvegarder des données dans Golang en utilisant différentes méthodes, notamment en utilisant des bases de données JSON, SQL et NoSQL. Chacune de ces méthodes présente des avantages et des cas d’utilisation différents. Les développeurs doivent choisir le mode de préservation des données qui correspond le mieux aux besoins de leur projet. 🎜

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