Pelajari fungsi pangkalan data dalam bahasa Go dan laksanakan operasi baca dan tulis dalam kelompok Redis
Pengenalan:
Pangkalan data merupakan bahagian yang amat diperlukan dalam aplikasi Internet hari ini, dan bahasa Go, sebagai bahasa pengaturcaraan yang mudah dan cekap, juga mempunyai keupayaan operasi Pangkalan Data yang baik . Artikel ini akan memperkenalkan cara menggunakan fungsi pangkalan data dalam bahasa Go dan melaksanakan operasi baca dan tulis dalam kelompok Redis.
1. Fungsi pangkalan data dalam bahasa Go
Operasi pangkalan data dalam bahasa Go dilaksanakan terutamanya melalui pakej pangkalan data/sql. Pakej ini menyediakan fungsi operasi pangkalan data asas, termasuk menyambung ke pangkalan data, melaksanakan pernyataan SQL, memproses set hasil, dsb.
Sambung ke pangkalan data
Dalam bahasa Go, kita boleh menyambung ke pangkalan data melalui fungsi Buka dalam pakej pangkalan data/sql. Fungsi ini menerima dua parameter: nama pemacu pangkalan data dan maklumat sambungan pangkalan data, contohnya:
import "database/sql" import _ "github.com/go-sql-driver/mysql" db, err := sql.Open("mysql", "root:password@tcp(127.0.0.1:3306)/database") if err != nil { log.Fatal(err) } defer db.Close()
Dalam kod di atas, kami menggunakan pemacu mysql untuk menyambung ke pangkalan data MySQL tempatan Nama pengguna ialah root, kata laluan ialah kata laluan, dan nama pangkalan data ialah pangkalan data.
Melaksanakan pernyataan SQL
Selepas menyambung ke pangkalan data, kami boleh melaksanakan pernyataan SQL melalui fungsi seperti db.Exec atau db.Query. Fungsi Exec digunakan untuk melaksanakan pernyataan SQL yang tidak mengembalikan set hasil, seperti memasukkan, mengemas kini, memadam, dsb. Fungsi Pertanyaan digunakan untuk melaksanakan pernyataan SQL yang mengembalikan set hasil, seperti operasi pertanyaan. Contohnya adalah seperti berikut:
stmt, err := db.Prepare("INSERT INTO users(email, password) VALUES(?, ?)") if err != nil { log.Fatal(err) } defer stmt.Close() result, err := stmt.Exec("test@example.com", "password123") if err != nil { log.Fatal(err) } lastInsertID, err := result.LastInsertId() if err != nil { log.Fatal(err) } fmt.Println(lastInsertID)
Dalam kod di atas, kami menggunakan fungsi Sediakan untuk menyusun awal pernyataan sisipan dan mengikat parameter kepada ?, dan kemudian laksanakan pernyataan sisipan melalui fungsi Exec, dan hasil pulangan disimpan dalam pembolehubah hasil. ID kenaikan automatik data yang dimasukkan boleh diperolehi melalui result.LastInsertId().
Memproses set hasil
Apabila melaksanakan pernyataan SQL yang mengembalikan set hasil, kita boleh menggunakan fungsi Rows untuk mendapatkan hasil pertanyaan. Kemudian setiap sekeping data diproses dengan menggelung melalui set hasil Contoh adalah seperti berikut:
rows, err := db.Query("SELECT id, email FROM users") if err != nil { log.Fatal(err) } defer rows.Close() for rows.Next() { var id int var email string err := rows.Scan(&id, &email) if err != nil { log.Fatal(err) } fmt.Println(id, email) }
Dalam kod di atas, kami melaksanakan pernyataan pertanyaan melalui fungsi db.Query dan menyimpan hasilnya dalam pembolehubah baris. Kemudian lintasi setiap keping data melalui baris.Seterusnya, dan simpan data ke pembolehubah yang sepadan melalui baris.Imbas.
2. Laksanakan operasi baca dan tulis dalam kelompok Redis
Redis ialah pangkalan data storan nilai kunci berprestasi tinggi yang boleh dikendalikan dalam bahasa Go melalui pakej go-redis/redis. Seterusnya kita akan menggunakan pakej ini untuk melaksanakan operasi baca dan tulis dalam kelompok Redis.
Menyambung ke gugusan Redis
Dalam bahasa Go, kita boleh menyambung ke gugusan Redis melalui fungsi redis.NewClusterClient. Contohnya adalah seperti berikut:
import "github.com/go-redis/redis/v8" cluster := redis.NewClusterClient(&redis.ClusterOptions{ Addrs: []string{"node1:6379", "node2:6379", "node3:6379"}, }) defer cluster.Close()
Dalam kod di atas, kami mencipta objek redis.ClusterClient dan menentukan alamat nod gugusan Redis melalui parameter ClusterOptions.
Tulis data ke gugusan Redis
Selepas menyambung ke gugusan Redis, kita boleh menggunakan fungsi Set untuk menulis data ke gugusan. Contohnya adalah seperti berikut:
err := cluster.Set(context.Background(), "key", "value", 0).Err() if err != nil { log.Fatal(err) }
Dalam kod di atas, kami menulis sekeping data nilai kunci ke gugusan Redis melalui gugusan. Tetapkan masa tamat tempoh ialah 0, yang bermaksud ia tidak akan tamat tempoh.
Membaca data daripada gugusan Redis
Selepas menyambung ke gugusan Redis, kita boleh menggunakan fungsi Dapatkan untuk membaca data daripada gugusan. Contohnya adalah seperti berikut:
val, err := cluster.Get(context.Background(), "key").Result() if err != nil { log.Fatal(err) } fmt.Println(val)
Dalam kod di atas, kita membaca nilai yang sepadan dengan kunci daripada gugusan Redis melalui gugusan. Dapatkan fungsi dan cetaknya.
Ringkasan:
Artikel ini memperkenalkan fungsi pangkalan data dalam pembelajaran bahasa Go dan melaksanakan operasi baca dan tulis kelompok Redis. Melalui fungsi pangkalan data, kami boleh menyambung ke pangkalan data dengan mudah, melaksanakan pernyataan SQL dan memproses set hasil. Melalui pakej go-redis/redis, kami boleh berinteraksi dengan gugusan Redis dengan mudah untuk mencapai operasi penyimpanan dan bacaan yang cekap. Saya harap artikel ini dapat membantu pembaca memahami dengan lebih baik fungsi pangkalan data dalam bahasa Go dan menggunakannya pada projek sebenar.
Atas ialah kandungan terperinci Ketahui fungsi pangkalan data dalam bahasa Go dan laksanakan operasi baca dan tulis dalam kelompok Redis. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!