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

可以通过使用 gjson 库或 json.unmarshal 函数将 json 数据保存到 mysql 数据库中。gjson 库提供了方便的方法来解析 json 字段,而 json.unmarshal 函数需要一个目标类型指针来解组 jso

可以通过使用 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.php.cn/zt/15841.html" 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")
}

登录后复制

以上就是如何在 Golang 中将 JSON 数据保存到数据库中?的详细内容,更多请关注叮当号网其它相关文章!

文章来自互联网,只做分享使用。发布者:,转转请注明出处:https://www.dingdanghao.com/article/501578.html

(0)
上一篇 2024-05-18 08:40
下一篇 2024-05-18 08:40

相关推荐

联系我们

在线咨询: QQ交谈

邮件:442814395@qq.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信公众号