Heim > Backend-Entwicklung > Golang > Wie speichere ich JSON-Daten in einer Datenbank in Golang?

Wie speichere ich JSON-Daten in einer Datenbank in Golang?

PHPz
Freigeben: 2024-06-06 11:24:57
Original
744 Leute haben es durchsucht

JSON-Daten können mithilfe der gjson-Bibliothek oder der json.Unmarshal-Funktion in einer MySQL-Datenbank gespeichert werden. Die gjson-Bibliothek bietet praktische Methoden zum Parsen von JSON-Feldern, und die Funktion json.Unmarshal erfordert einen Zieltypzeiger zum Unmarshalieren von JSON-Daten. Bei beiden Methoden müssen SQL-Anweisungen vorbereitet und Einfügevorgänge ausgeführt werden, um die Daten in der Datenbank beizubehalten.

如何在 Golang 中将 JSON 数据保存到数据库中?

So speichern Sie JSON-Daten in einer Datenbank in Golang

Einführung
In Golang ist das Speichern von JSON-Daten in einer Datenbank eine häufige Aufgabe. In diesem Artikel werden verschiedene Methoden zur Beibehaltung von JSON-Daten unter Verwendung häufig verwendeter Datenbanken wie MySQL untersucht und praktische Beispiele als Referenz bereitgestellt.

Verwendung der GJSON-Bibliothek
Die GJSON-Bibliothek ist ein beliebtes Golang-Paket zum Parsen und Bearbeiten von JSON-Daten. Es bietet einfache Methoden zum Parsen von JSON-Daten in Go-Datenstrukturen wie Karten und Slices.

package main

import (
    "database/sql"
    "encoding/json"
    "fmt"
    _ "github.com/go-sql-driver/mysql"
    "github.com/tidwall/gjson"
)

func main() {
    db, err := sql.Open("mysql", "user:password@tcp(localhost:3306)/database")
    if err != nil {
        panic(err)
    }
    defer db.Close()

    jsonData := `{
        "name": "John Doe",
        "age": 30,
        "address": {
            "street": "Main Street",
            "city": "New York"
        }
    }`

    values := []interface{}{}

    // 解析 JSON 字段
    name := gjson.Get(jsonData, "name").String()
    age := gjson.Get(jsonData, "age").Int()
    address := gjson.Get(jsonData, "address").String()

    values = append(values, name, age, address)

    // 准备 SQL 语句
    stmt, err := db.Prepare("INSERT INTO users (name, age, address) VALUES (?, ?, ?)")
    if err != nil {
        panic(err)
    }

    // 执行插入操作
    _, err = stmt.Exec(values...)
    if err != nil {
        panic(err)
    }

    fmt.Println("JSON data saved to database successfully")
}
Nach dem Login kopieren

Verwendung von json.Unmarshal
Die Funktion json.Unmarshal ist Teil der Golang-Standardbibliothek und wird zum Unmarshalieren von JSON-Daten in Go-Variablen verwendet. Diese Methode erfordert einen Zieltypzeiger als zweiten Parameter.

package main

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

func main() {
    db, err := sql.Open("mysql", "user:password@tcp(localhost:3306)/database")
    if err != nil {
        panic(err)
    }
    defer db.Close()

    jsonData := `{
        "name": "John Doe",
        "age": 30,
        "address": {
            "street": "Main Street",
            "city": "New York"
        }
    }`

    var user struct {
        Name     string
        Age      int
        Address  string
    }

    err = json.Unmarshal([]byte(jsonData), &user)
    if err != nil {
        panic(err)
    }

    // 准备 SQL 语句
    stmt, err := db.Prepare("INSERT INTO users (name, age, address) VALUES (?, ?, ?)")
    if err != nil {
        panic(err)
    }

    // 执行插入操作
    _, err = stmt.Exec(user.Name, user.Age, user.Address)
    if err != nil {
        panic(err)
    }

    fmt.Println("JSON data saved to database successfully")
}
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie speichere ich JSON-Daten in einer Datenbank in Golang?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage