JSON 데이터는 gjson 라이브러리 또는 json.Unmarshal 함수를 사용하여 MySQL 데이터베이스에 저장할 수 있습니다. gjson 라이브러리는 JSON 필드를 구문 분석하기 위한 편리한 방법을 제공하며, json.Unmarshal 함수에는 JSON 데이터를 비정렬화하기 위한 대상 유형 포인터가 필요합니다. 두 방법 모두 SQL 문을 준비하고 삽입 작업을 수행하여 데이터를 데이터베이스에 유지해야 합니다.
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!