Rumah pembangunan bahagian belakang Golang Bagaimana untuk menyimpan data JSON ke pangkalan data di Golang?

Bagaimana untuk menyimpan data JSON ke pangkalan data di Golang?

Jun 06, 2024 am 11:24 AM
json golang pangkalan data

Data JSON boleh disimpan ke dalam pangkalan data MySQL dengan menggunakan perpustakaan gjson atau fungsi json.Unmarshal. Pustaka gjson menyediakan kaedah kemudahan untuk menghuraikan medan JSON dan fungsi json.Unmarshal memerlukan penunjuk jenis sasaran kepada data JSON unmarshal. Kedua-dua kaedah memerlukan penyediaan pernyataan SQL dan melaksanakan operasi sisipan untuk mengekalkan data ke dalam pangkalan data.

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

Cara menyimpan data JSON ke pangkalan data di Golang

Pengenalan
Di Golang, menyimpan data JSON ke pangkalan data adalah tugas biasa. Artikel ini akan meneroka kaedah yang berbeza untuk meneruskan data JSON menggunakan pangkalan data yang biasa digunakan seperti MySQL, dan menyediakan contoh praktikal untuk rujukan.

Menggunakan perpustakaan gjson
Pustaka gjson ialah pakej Golang yang popular untuk menghuraikan dan memanipulasi data JSON. Ia menyediakan kaedah mudah untuk menghuraikan data JSON ke dalam struktur data Go seperti peta dan kepingan.

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")
}

Menggunakan json.Unmarshal
Fungsi json.Unmarshal ialah sebahagian daripada pustaka standard Golang dan digunakan untuk menyahmarshal data JSON ke dalam pembolehubah Go. Kaedah ini memerlukan penunjuk jenis sasaran sebagai parameter kedua.

rreeee

Atas ialah kandungan terperinci Bagaimana untuk menyimpan data JSON ke pangkalan data di Golang?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Stock Market GPT

Stock Market GPT

Penyelidikan pelaburan dikuasakan AI untuk keputusan yang lebih bijak

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Apakah struct struktur kosong {} yang digunakan di Golang Apakah struct struktur kosong {} yang digunakan di Golang Sep 18, 2025 am 05:47 AM

Struct {} adalah struktur tanpa medan di GO, yang menduduki bait sifar dan sering digunakan dalam senario di mana data tidak diperlukan. Ia digunakan sebagai isyarat dalam saluran, seperti penyegerakan goroutine; 2. Digunakan sebagai koleksi jenis nilai peta untuk mencapai pemeriksaan kewujudan utama dalam ingatan yang cekap; 3. Penerima kaedah tanpa stateless yang pasti, sesuai untuk suntikan pergantungan atau fungsi organisasi. Jenis ini digunakan secara meluas untuk mengekspresikan aliran kawalan dan niat yang jelas.

Bagaimana anda membaca dan menulis fail di Golang? Bagaimana anda membaca dan menulis fail di Golang? Sep 21, 2025 am 01:59 AM

Goprovidessimpleandefficientfilehandlingingtheosandbufiopackages.toreadasmallfileentirely, useos.readfile, whittloadsthecontentintomemorysafelyandautomatikManageSoperations.forlargefilesorincrementalprementalprementalprementrementprementalplocessing,

Apakah middleware dalam konteks pelayan web Golang? Apakah middleware dalam konteks pelayan web Golang? Sep 16, 2025 am 02:16 AM

MiddlewareinGowebserversarefunctionsthatinterceptHTTPrequestsbeforetheyreachthehandler,enablingreusablecross-cuttingfunctionality;theyworkbywrappinghandlerstoaddpre-andpost-processinglogicsuchaslogging,authentication,CORS,orerrorrecovery,andcanbechai

Bagaimana untuk membuat objek JSON dalam PHP? Bagaimana untuk membuat objek JSON dalam PHP? Sep 22, 2025 am 04:13 AM

Gunakan fungsi JSON_ENCODE () untuk menukar susunan atau objek PHP ke dalam rentetan JSON. Sebagai contoh, array bersekutu ["nama" => "John", "Age" => 30, "City" => "NewYork"] output {"name": "John", "umur": 30, "City": "NewYork &

Versi Kemas Kini Linkfox Mengatasi Arahan Pemasangan - Versi LinkFox Meningkatkan Migrasi Data Pemasangan Versi Kemas Kini Linkfox Mengatasi Arahan Pemasangan - Versi LinkFox Meningkatkan Migrasi Data Pemasangan Sep 16, 2025 pm 02:12 PM

Pertama, sandarkan data konfigurasi dan projek, kemudian lakukan pemasangan overlay versi baru dan secara manual memindahkan data. Khususnya: 1. Sandarkan folder konfigurasi dan projek; 2. Selepas menutup program, pemasangan tersuai ke direktori asal; 3. Salin kandungan sandaran ke direktori data versi baru dan sahkan sama ada fungsi projek dan antara muka adalah normal.

Cara menghuraikan rentetan JSON ke dalam objek JavaScript Cara menghuraikan rentetan JSON ke dalam objek JavaScript Sep 21, 2025 am 05:43 AM

Untuk menghuraikan tali JSON ke dalam objek JavaScript, anda harus menggunakan kaedah JSON.Parse (), yang boleh menukar rentetan JSON yang sah ke dalam objek JavaScript yang sepadan, menyokong parsing objek dan tatasusunan bersarang, tetapi akan membuang kesilapan untuk JSON yang tidak sah. Oleh itu, anda perlu menggunakan cuba ... menangkap untuk mengendalikan pengecualian. Pada masa yang sama, anda boleh menukar nilai semasa parsing melalui fungsi reviver parameter kedua, seperti menukar rentetan tarikh ke dalam objek tarikh, dengan itu mencapai penukaran data yang selamat dan boleh dipercayai.

Bagaimana anda mengendalikan penutupan anggun dalam aplikasi Golang? Bagaimana anda mengendalikan penutupan anggun dalam aplikasi Golang? Sep 21, 2025 am 02:30 AM

Anggap yang mengasyik,

Apa itu CGO dan bila menggunakannya di Golang Apa itu CGO dan bila menggunakannya di Golang Sep 21, 2025 am 02:55 AM

Cgoenablesgotocallccode, membolehkanIntegrationWithClibrariesLikeopenssl, AccessTolow-levelsystemapi, danPerformanceoptimization; iTrequiresimporting "C" withcheadersincomments, usesc.function () syntax, dandemandscareffemoryMangage

See all articles