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.
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
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) }
上述代码将检索所有人的数据并将其打印在控制台上。
与SQL数据库不同,NoSQL数据库更适合非结构化的数据。Golang中最流行的NoSQL数据库之一是MongoDB。我们可以使用mgo
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) }
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) }
json.Unmarshal()
pour décoder JSON en une struct : rrreee
Sortie :rrreee
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.
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. 🎜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!