欢迎光临
我们一直在努力

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

可以通过使用 gjson 库或 json.unmarshal 函数将 json 数据保存到 mysql 数据库中。gjson 库提供了方便的方法来解析 json 字段,而 json.unmarshal 函数需要一个目标类型指针来解组 json 数据。这两种方法都需要准备 sql 语句和执行插入操作来将数据持久化到数据库中。

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

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

引言
在 Golang 中,将 JSON 数据保存到数据库是一个常见任务。本文将探讨使用常用数据库(如 MySQL)将 JSON 数据持久化的不同方法,并提供实战案例以供参考。

使用 gjson 库
gjson 库是一个流行的 Golang 包,用于解析和操作 JSON 数据。它提供了简单的方法将 JSON 数据解析为 Go 数据结构,例如 map 和 slice。

package main

import (
    "database/sql"
    "encoding/json"
    "fmt"
    _ "<a style='color:#f60; text-decoration:underline;' href="https://www.codesou.cn/" target="_blank">git</a>hub.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")
}

使用 json.Unmarshal
json.Unmarshal 函数是 Golang 标准库的一部分,用于将 JSON 数据解组到 Go 变量中。此方法需要一个目标类型指针作为第二个参数。

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")
}
赞(0) 打赏
未经允许不得转载:码农资源网 » 如何在 Golang 中将 JSON 数据保存到数据库中?
分享到

觉得文章有用就打赏一下文章作者

非常感谢你的打赏,我们将继续提供更多优质内容,让我们一起创建更加美好的网络世界!

支付宝扫一扫打赏

微信扫一扫打赏

登录

找回密码

注册