Rumah  >  Artikel  >  pangkalan data  >  Cara membuat operasi kemas kini MySQL berprestasi tinggi menggunakan bahasa Go

Cara membuat operasi kemas kini MySQL berprestasi tinggi menggunakan bahasa Go

WBOY
WBOYasal
2023-06-17 13:28:401625semak imbas

Dalam aplikasi web moden, pangkalan data adalah bahagian yang tidak dapat dielakkan. MySQL ialah sistem pengurusan pangkalan data hubungan yang biasa digunakan yang serasi dengan banyak bahasa pengaturcaraan. Go ialah bahasa pengaturcaraan yang disertakan dengan keupayaan konkurensi dan mudah untuk ditulis. Dalam artikel ini, kami akan memperkenalkan cara menggabungkan bahasa Go dan MySQL untuk mencipta operasi kemas kini pangkalan data berprestasi tinggi.

  1. Menyambung ke pangkalan data MySQL

Sebelum anda bermula, anda perlu memastikan bahawa anda telah memasang dan mengkonfigurasi pangkalan data MySQL. Kami menggunakan pemacu MySQL terbina dalam bahasa Go untuk menyambung ke pangkalan data MySQL. Contohnya:

import (
    "database/sql"
    _ "github.com/go-sql-driver/mysql"
)

func main() {
    //连接MySQL数据库
    db, err := sql.Open("mysql", "username:password@tcp(127.0.0.1:3306)/dbname")
    if err != nil{
        panic(err.Error())
    }
    defer db.Close()
}

Rentetan sambungan mengandungi nama pengguna, kata laluan dan nama pangkalan data. Setelah sambungan berjaya diwujudkan, anda boleh melaksanakan sebarang pertanyaan MySQL dan memproses hasilnya.

  1. Lakukan operasi kemas kini MySQL

Dalam MySQL, operasi kemas kini menggunakan pernyataan KEMASKINI, yang membolehkan anda mengemas kini satu atau lebih baris data dalam jadual. Berikut ialah contoh mudah:

_, err := db.Exec("UPDATE table_name SET column1='value1', column2='value2' WHERE condition")
if err != nil {
    panic(err.Error())
}

Dalam pertanyaan ini, kami menetapkan nilai lajur1 dan lajur2 masing-masing kepada nilai1 dan nilai2, dan mengemas kini hanya baris yang memenuhi kriteria yang ditentukan. Pembolehubah _ digunakan untuk mengabaikan bilangan baris yang dikembalikan oleh kaedah Exec().

  1. Kemas Kini Kelompok

Jika anda perlu mengemas kini berbilang baris data, melaksanakan satu kemas kini pada satu masa akan memakan masa yang sangat lama. Untuk kes ini, anda boleh menggunakan operasi kemas kini pukal MySQL. Operasi kemas kini kelompok menggabungkan berbilang kenyataan kemas kini dan menyerahkannya ke pangkalan data bersama-sama. Ini boleh meningkatkan prestasi dengan ketara.

Kami boleh melaksanakan kemas kini kelompok menggunakan kod berikut:

//准备更新数据
data := []struct {
    id   int
    name string
}{
    {1, "John"},
    {2, "Mary"},
    {3, "David"},
}

//生成更新语句
update := "UPDATE table_name SET name = CASE id "
params := []interface{}{}
for _, d := range data {
    update += "WHEN ? THEN ? "
    params = append(params, d.id, d.name)
}
update += "ELSE name END"
_, err := db.Exec(update, params...)
if err != nil {
    panic(err.Error())
}

Contoh ini menjana pernyataan KEMASKINI yang mengandungi berbilang klausa WHEN. Setiap klausa WHEN mengemas kini nilai lajur nama bagi baris dalam jadual di mana lajur id adalah sama dengan nilai yang ditentukan. Akhir sekali, keseluruhan operasi kemas kini dilakukan menggunakan pernyataan CASE.

Parameter params ialah kepingan yang mengandungi semua parameter mengikut urutan. Dalam kaedah Exec(), kami menghantar rentetan kemas kini yang dijana dan kepingan parameter sebagai parameter.

  1. Kemas kini serentak

Prestasi serentak bahasa Go ialah salah satu cirinya yang paling menonjol. Pada masa yang sama, MySQL juga membenarkan berbilang pelanggan untuk menyambung ke pangkalan data secara serentak. Menggabungkan kedua-dua ciri ini, kami boleh menggunakan berbilang coroutine untuk melaksanakan operasi kemas kini MySQL secara serentak untuk meningkatkan lagi prestasi.

Berikut ialah contoh kemas kini serentak yang mudah:

//定义更新函数
func update(db *sql.DB, data []struct {
    id   int
    name string
}, ch chan bool) {
    defer func() {
        ch <- true
    }()
    tx, err := db.Begin()
    if err != nil {
        panic(err.Error())
    }
    for _, d := range data {
        _, err = tx.Exec("UPDATE table_name SET name = ? WHERE id = ?", d.name, d.id)
        if err != nil {
            panic(err.Error())
        }
    }
    err = tx.Commit()
    if err != nil {
        panic(err.Error())
    }
}

//创建goroutine并执行更新
data := []struct {
    id   int
    name string
}{
    {1, "John"},
    {2, "Mary"},
    {3, "David"},
}
ch := make(chan bool, 10)
for i := 0; i < 10; i++ {
    go update(db, data, ch)
}
for i := 0; i < 10; i++ {
    <-ch
}

Dalam contoh ini, kami mentakrifkan fungsi yang dipanggil kemas kini() yang menerima kepingan data, sambungan pangkalan data dan saluran sebagai parameter . Fungsi ini menggunakan transaksi untuk melaksanakan semua kemas kini dalam kepingan data. Akhir sekali, saluran digunakan untuk memberitahu fungsi utama bahawa operasi kemas kini telah selesai.

Dalam fungsi utama, kami mencipta 10 gorout untuk melaksanakan operasi kemas kini secara serentak dan menggunakan saluran untuk menunggu selesainya.

  1. Ringkasan

Bahasa Go ialah bahasa pengaturcaraan berkuasa yang boleh disepadukan dengan lancar dengan sistem pangkalan data yang biasa digunakan seperti MySQL. Menggunakan bahasa Go dan MySQL, kami boleh mencipta operasi kemas kini pangkalan data berprestasi tinggi. Artikel ini memperkenalkan penyambungan kepada pangkalan data MySQL, melaksanakan operasi kemas kini MySQL, kemas kini kelompok, kemas kini serentak, dll. Saya harap ia dapat membantu anda menggunakan kelebihan prestasi bahasa Go dan MySQL dengan lebih baik.

Atas ialah kandungan terperinci Cara membuat operasi kemas kini MySQL berprestasi tinggi menggunakan bahasa Go. 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