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.
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.
Langkah pertama ialah memasang dependencies yang diperlukan:
import ( "context" "fmt" "log" "cloud.google.com/go/spanner" )
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
是一个迭代器,它将遍历查询结果。
要处理结果,请使用 Do
rreee
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 keputusanUntuk memproses keputusan, sila gunakan kaedah Do
: 🎜client.Close()
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) } }
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!