> 백엔드 개발 > Golang > JSON 데이터를 Golang의 데이터베이스에 저장하는 방법은 무엇입니까?

JSON 데이터를 Golang의 데이터베이스에 저장하는 방법은 무엇입니까?

PHPz
풀어 주다: 2024-06-06 11:24:57
원래의
757명이 탐색했습니다.

JSON 데이터는 gjson 라이브러리 또는 json.Unmarshal 함수를 사용하여 MySQL 데이터베이스에 저장할 수 있습니다. gjson 라이브러리는 JSON 필드를 구문 분석하기 위한 편리한 방법을 제공하며, json.Unmarshal 함수에는 JSON 데이터를 비정렬화하기 위한 대상 유형 포인터가 필요합니다. 두 방법 모두 SQL 문을 준비하고 삽입 작업을 수행하여 데이터를 데이터베이스에 유지해야 합니다.

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

JSON 데이터를 Golang의 데이터베이스에 저장하는 방법

소개
Golang에서는 JSON 데이터를 데이터베이스에 저장하는 것이 일반적인 작업입니다. 이 기사에서는 MySQL과 같이 일반적으로 사용되는 데이터베이스를 사용하여 JSON 데이터를 유지하는 다양한 방법을 살펴보고 참조할 수 있는 실제 예제를 제공합니다.

gjson 라이브러리 사용
gjson 라이브러리는 JSON 데이터를 구문 분석하고 조작하는 데 널리 사용되는 Golang 패키지입니다. JSON 데이터를 맵 및 슬라이스와 같은 Go 데이터 구조로 구문 분석하는 쉬운 방법을 제공합니다.

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")
}
로그인 후 복사

json.Unmarshal 사용
json.Unmarshal 함수는 Golang 표준 라이브러리의 일부이며 JSON 데이터를 Go 변수로 역마샬링하는 데 사용됩니다. 이 메서드에는 두 번째 매개변수로 대상 유형 포인터가 필요합니다.

아아아아

위 내용은 JSON 데이터를 Golang의 데이터베이스에 저장하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿