cari
Rumahpembangunan bahagian belakangGolangInteraksi antara fungsi Golang dan pangkalan data teragih dalam sistem teragih

Interaksi antara fungsi Golang dan pangkalan data teragih dalam sistem teragih

Apr 19, 2024 pm 03:06 PM
golangPangkalan data yang diedarkansistem teragih

Dalam sistem teragih, fungsi Go boleh berinteraksi dengan pangkalan data teragih. Langkah-langkah khusus adalah seperti berikut: Pasang kebergantungan yang diperlukan. Gunakan fungsi spanner.NewClient untuk menyambung ke pangkalan data. Gunakan kaedah Pertanyaan untuk melaksanakan pertanyaan dan dapatkan iterator. Gunakan kaedah Do untuk mengulangi hasil pertanyaan dan memproses data. Selepas pertanyaan selesai, gunakan kaedah Tutup untuk menutup sambungan.

分布式系统中 Golang 函数与分布式数据库的交互

Interaksi antara fungsi Go dan pangkalan data teragih dalam sistem teragih

Dalam sistem teragih, adalah keperluan biasa untuk fungsi Go berinteraksi dengan pangkalan data teragih. Artikel ini membimbing anda menggunakan kod Go untuk menyambung ke dan menanyakan pangkalan data yang diedarkan.

Pasang dependencies

Langkah pertama ialah memasang dependencies yang diperlukan:

import (
    "context"
    "fmt"
    "log"

    "cloud.google.com/go/spanner"
)

Sambung ke pangkalan data

Untuk menyambung ke pangkalan data, gunakan fungsi spanner.NewClient: spanner.NewClient 函数:

client, err := spanner.NewClient(context.Background(), "projects/my-project", "instances/my-instance", "databases/my-database")
if err != nil {
    log.Fatal(err)
}

执行查询

要执行查询,请使用 Query 方法:

stmt := spanner.Statement{SQL: `SELECT * FROM Singers`}
iter := client.Single().Query(context.Background(), stmt)
defer iter.Stop()

iter 是一个迭代器,它将遍历查询结果。

处理结果

要处理结果,请使用 Dorreee

Laksanakan query

Untuk melaksanakan pertanyaan, gunakan kaedah Query:

for {
    row, err := iter.Next()
    if err == iterator.Done {
        break
    }
    if err != nil {
        log.Fatal(err)
    }
    var singerId int64
    var firstName string
    var lastName string
    if err := row.ColumnByName("SingerId", &singerId); err != nil {
        log.Fatal(err)
    }
    if err := row.ColumnByName("FirstName", &firstName); err != nil {
        log.Fatal(err)
    }
    if err := row.ColumnByName("LastName", &lastName); err != nil {
        log.Fatal(err)
    }
    fmt.Printf("%d %s %s\n", singerId, firstName, lastName)
}

iter ialah iterator yang akan berulang pada hasil pertanyaan.

Memproses keputusan

Untuk memproses keputusan, sila gunakan kaedah Do: 🎜
client.Close()
🎜Tutup sambungan🎜🎜Selepas pertanyaan selesai, sila tutup sambungan ke pangkalan data: 🎜
package main

import (
    "context"
    "fmt"
    "log"

    "cloud.google.com/go/spanner"
)

func main() {
    client, err := spanner.NewClient(context.Background(), "projects/my-project", "instances/my-instance", "databases/my-database")
    if err != nil {
        log.Fatal(err)
    }
    defer client.Close()

    stmt := spanner.Statement{SQL: `SELECT * FROM Singers`}
    iter := client.Single().Query(context.Background(), stmt)
    defer iter.Stop()

    for {
        row, err := iter.Next()
        if err == iterator.Done {
            break
        }
        if err != nil {
            log.Fatal(err)
        }
        var singerId int64
        var firstName string
        var lastName string
        if err := row.ColumnByName("SingerId", &singerId); err != nil {
            log.Fatal(err)
        }
        if err := row.ColumnByName("FirstName", &firstName); err != nil {
            log.Fatal(err)
        }
        if err := row.ColumnByName("LastName", &lastName); err != nil {
            log.Fatal(err)
        }
        fmt.Printf("%d %s %s\n", singerId, firstName, lastName)
    }
}
🎜Kes sebenar 🎜🎜Berikut ialah satu contoh kod Complete Go yang menunjukkan cara menyambung ke pangkalan data Cloud Spanner dan melaksanakan pertanyaan: 🎜rrreee

Atas ialah kandungan terperinci Interaksi antara fungsi Golang dan pangkalan data teragih dalam sistem teragih. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
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
Memahami Goroutine: menyelam mendalam ke go's concurrencyMemahami Goroutine: menyelam mendalam ke go's concurrencyMay 01, 2025 am 12:18 AM

Goroutinesarefunctionsormethodsthatrunconcurlyingo, enablingefficientandlightweightconcurrency.1) theareManagedBygo'sruntimeusingmultiplexing, membolehkanThousthyandstorunonfewerthreads.2) goroutinesimproveprovperformancethoaseaseaseasyfaskmismenteFf

Memahami fungsi init di GO: Tujuan dan PenggunaanMemahami fungsi init di GO: Tujuan dan PenggunaanMay 01, 2025 am 12:16 AM

Thepurposeoftheinitfunctioningoistoinitializevariables, setupconfigurations, orperformnessarysetupbeforethemainfunctionExecutes.useinitby: 1) Placingitinyourcodetorunautomaticallybeforemain, 2) penyimpanan

Memahami Antara muka: Panduan KomprehensifMemahami Antara muka: Panduan KomprehensifMay 01, 2025 am 12:13 AM

Gointerfacesaremethodsignaturesetsthattypesmustimplement,enablingpolymorphismwithoutinheritanceforcleaner,modularcode.Theyareimplicitlysatisfied,usefulforflexibleAPIsanddecoupling,butrequirecarefulusetoavoidruntimeerrorsandmaintaintypesafety.

Pulih dari panik di Go: Bila dan Cara Menggunakan Pulih ()Pulih dari panik di Go: Bila dan Cara Menggunakan Pulih ()May 01, 2025 am 12:04 AM

Gunakan fungsi pulih () dalam GO untuk pulih dari panik. Kaedah khusus adalah: 1) Gunakan pulih () untuk menangkap panik dalam fungsi penangguhan untuk mengelakkan kemalangan program; 2) rekod maklumat ralat terperinci untuk debugging; 3) memutuskan sama ada untuk meneruskan pelaksanaan program berdasarkan keadaan tertentu; 4) Gunakan dengan berhati -hati untuk mengelakkan mempengaruhi prestasi.

Bagaimana anda menggunakan & quot; Strings & quot; Pakej untuk memanipulasi rentetan dalam perjalanan?Bagaimana anda menggunakan & quot; Strings & quot; Pakej untuk memanipulasi rentetan dalam perjalanan?Apr 30, 2025 pm 02:34 PM

Artikel ini membincangkan menggunakan pakej "Strings" Go untuk manipulasi rentetan, memperincikan fungsi umum dan amalan terbaik untuk meningkatkan kecekapan dan mengendalikan Unicode dengan berkesan.

Bagaimana anda menggunakan & quot; crypto & quot; Pakej untuk melakukan operasi kriptografi di GO?Bagaimana anda menggunakan & quot; crypto & quot; Pakej untuk melakukan operasi kriptografi di GO?Apr 30, 2025 pm 02:33 PM

Butiran artikel menggunakan pakej "crypto" Go untuk operasi kriptografi, membincangkan generasi utama, pengurusan, dan amalan terbaik untuk pelaksanaan yang selamat.

Bagaimana anda menggunakan & quot; masa & quot; pakej untuk mengendalikan tarikh dan masa dalam perjalanan?Bagaimana anda menggunakan & quot; masa & quot; pakej untuk mengendalikan tarikh dan masa dalam perjalanan?Apr 30, 2025 pm 02:32 PM

Artikel ini memperincikan penggunaan pakej "masa" Go untuk pengendalian tarikh, masa, dan zon masa, termasuk mendapatkan masa semasa, mewujudkan masa tertentu, rentetan parsing, dan mengukur masa berlalu.

Bagaimana anda menggunakan & quot; mencerminkan & quot; pakej untuk memeriksa jenis dan nilai pembolehubah dalam GO?Bagaimana anda menggunakan & quot; mencerminkan & quot; pakej untuk memeriksa jenis dan nilai pembolehubah dalam GO?Apr 30, 2025 pm 02:29 PM

Artikel membincangkan menggunakan pakej "mencerminkan" Go untuk pemeriksaan dan pengubahsuaian yang berubah -ubah, menonjolkan kaedah dan pertimbangan prestasi.

See all articles

Alat AI Hot

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.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

Muat turun versi mac editor Atom

Muat turun versi mac editor Atom

Editor sumber terbuka yang paling popular

VSCode Windows 64-bit Muat Turun

VSCode Windows 64-bit Muat Turun

Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft