Rumah pembangunan bahagian belakang Golang pertanyaan golang mysql

pertanyaan golang mysql

May 21, 2023 pm 04:52 PM

Dalam pembangunan perisian moden, memproses sejumlah besar data adalah tugas yang sangat biasa. Menyimpan dan menanyakan data ini dalam MySQL, salah satu pangkalan data yang paling biasa, adalah salah satu kemahiran penting untuk pembangun rangka kerja. Dalam artikel ini, kami akan meneroka cara membuat pertanyaan MySQL menggunakan Golang, bahasa pengaturcaraan yang dibangunkan oleh Google dan cara menggunakan perpustakaan pihak ketiga sumber terbuka untuk menyambung, membuat pertanyaan dan mengurus data.

Mengapa menggunakan Golang untuk menanyakan MySQL?

Golang ialah bahasa pengaturcaraan sumber terbuka yang pantas, boleh dipercayai dan berskala yang digunakan secara meluas dalam membina rangkaian berprestasi tinggi dan aplikasi serentak. Oleh kerana pengurusan ingatan yang cekap dan pemeriksaan jenis statik, Golang sesuai untuk mengendalikan sejumlah besar bacaan dan tulis serentak, operasi intensif pengiraan dan tugas pemprosesan data berskala besar.

MySQL ialah pangkalan data hubungan yang sering digunakan untuk menyimpan data berskala besar. Kelebihannya termasuk struktur data yang fleksibel, integriti data yang baik dan berskala tinggi. Ia bukan sahaja menyokong bahasa SQL standard, tetapi juga menyokong banyak pertanyaan data dan kaedah sambungan.

Oleh itu, menggabungkan Golang dengan MySQL akan menghasilkan kelebihan kedua-dua pihak dan merupakan pilihan yang sangat baik untuk aplikasi moden seperti penyimpanan data dan pertanyaan. Golang juga mempunyai banyak perpustakaan pihak ketiga untuk dipilih, yang boleh membantu menyambung, membuat pertanyaan dan mengurus pangkalan data MySQL, menjadikannya lebih mudah untuk menanyakan pangkalan data MySQL. Seterusnya, kami akan menerangkan cara menggunakan perpustakaan pihak ketiga-Go-MySQL-Driver untuk menyambung ke pangkalan data MySQL.

Query MySQL menggunakan Go-MySQL-Driver

Go-MySQL-Driver ialah perpustakaan sumber terbuka yang popular di Golang yang digunakan untuk menyambung dan mengendalikan MySQL. Ia menyediakan API mudah untuk menyambung dengan mudah ke contoh MySQL dan melaksanakan operasi pertanyaan data yang cekap. Operasi ini termasuk memilih, memasukkan, memadam dan mengemas kini data sedia ada, dsb. Yang berikut akan memperkenalkan secara terperinci cara menggunakan Go-MySQL-Driver untuk menyambung dan menanyakan pangkalan data MySQL.

Langkah 1: Pasang pustaka Go-MySQL-Driver

Untuk mula menggunakan Go-MySQL-Driver, anda perlu memasang pustaka Go-MySQL-Driver dalam projek Golang anda terlebih dahulu. Pasang Go-MySQL-Driver dalam projek anda menggunakan arahan berikut:

go get github.com/go-sql-driver/mysql
Salin selepas log masuk

Langkah 2: Sambung ke pelayan MySQL dan dapatkan data

Setelah perpustakaan Go-MySQL-Driver dipasang, anda boleh gunakan segmen kod berikut untuk menyambung ke pelayan MySQL. Berikut ialah contoh mudah:

package main

import (
    "database/sql"
    "fmt"

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

func main() {
    // 打开数据库连接,创建一个 db 变量
    // 第一个参数:指定使用 mysql 协议来连接数据库
    // 第二个参数:root 是 MySQL 的超级管理员账户名称
    // 第三个参数:mypass 是 MySQL 的管理员账户密码
    // 第四个参数:localhost 是 MySQL 数据库服务器的主机地址
    // 第五个参数:3306 是 MySQL 数据库服务器的端口号
    db, err := sql.Open("mysql", "root:mypass@tcp(localhost:3306)/")

    // 检查是否连接成功
    if err != nil {
        panic(err.Error())
    }

    // 关闭数据库连接
    defer db.Close()
    
    // 定义一个查询语句并执行
    rows, err := db.Query("SELECT name, age FROM users")
    if err != nil {
        panic(err.Error())
    }
    defer rows.Close()

    // 打印查询结果
    for rows.Next() {
        var name string
        var age int
        if err := rows.Scan(&name, &age); err != nil {
            panic(err.Error())
        }
        fmt.Printf("Name: %s, Age: %d
", name, age)
    }
}
Salin selepas log masuk

Dalam contoh ini, kami mula-mula menggunakan fungsi sql.Open untuk membuka sambungan ke contoh pangkalan data MySQL. db Pembolehubah mewakili pemegang sambungan, yang menyimpan maklumat lain yang diperlukan untuk sebarang operasi yang dilakukan dalam pangkalan data MySQL.

Setelah sambungan diwujudkan, kami menggunakan fungsi db.Query untuk menanyakan pangkalan data. Fungsi ini digunakan untuk melaksanakan pertanyaan SQL dan mengembalikan struktur sql.Rows. sql.Rows ialah set hasil untuk hasil pelaksanaan berulang.

Dalam contoh ini, kami melaksanakan pertanyaan SQL yang sangat mudah "SELECT name, age FROM users" dan menggunakan kaedah .Scan untuk menyimpan hasil dalam pembolehubah yang sepadan, kemudian lelaran ke atas keputusan dan mencetaknya.

Langkah 3: Lakukan operasi INSERT, UPDATE dan DELETE

Selain pertanyaan, Go-MySQL-Driver juga menyediakan API untuk melaksanakan operasi INSERT, UPDATE dan DELETE. Berikut ialah contoh:

package main

import (
    "database/sql"
    "fmt"

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

func main() {
    db, err := sql.Open("mysql", "root:mypass@tcp(localhost:3306)/")
    if err != nil {
        panic(err.Error())
    }

    // 关闭数据库连接
    defer db.Close()

    // 准备一个语句,对数据表进行插入操作
    stmt, err := db.Prepare("INSERT INTO users(name, age) VALUES(?, ?)")
    if err != nil {
        panic(err.Error())
    }

    // 插入数据
    res, err := stmt.Exec("Tom", 20)
    if err != nil {
        panic(err.Error())
    }

    // 获取插入数据的上一条语句的 ID
    id, err := res.LastInsertId()
    if err != nil {
        panic(err.Error())
    }

    fmt.Printf("Inserted record with ID %d
", id)
}
Salin selepas log masuk

Contoh ini menunjukkan cara menggunakan db.Prepare untuk membuat pernyataan yang disediakan yang akan memasukkan maklumat khusus semasa pelaksanaan berikutnya.

Contoh ini menggunakan ? pemegang tempat, seperti yang diterangkan di atas, dan bukannya merujuk pembolehubah sebenar dalam pernyataan SQL. Ia akan diganti apabila stmt dilaksanakan. Kaedah ini membantu mengelakkan kemungkinan suntikan SQL.

Apabila stmt sedia, kami memasukkan data ke dalam stmt, memasukkannya menggunakan kaedah stmt.Exec(). Kaedah stmt.Exec() akan mengembalikan hasil sql.Result yang merangkumi bilangan baris yang terjejas dan ID baris terakhir yang dimasukkan.

Dalam contoh ini, kami menggunakan kaedah res.LastInsertId() untuk mendapatkan ID.

Kesimpulan

Di atas adalah contoh mudah pertanyaan MySQL menggunakan Golang dan Go-MySQL-Driver. Ia boleh diramalkan bahawa lebih banyak tugas boleh dilakukan dengan menggabungkan Golang dan MySQL Contohnya, menggunakan gabungan ini dalam aplikasi berbilang peringkat abstrak boleh mengendalikan sejumlah besar tugasan penyimpanan data dan pertanyaan.

Sudah tentu, Go-MySQL-Driver mungkin bukan satu-satunya cara untuk menyambung dan mengendalikan MySQL. Golang mempunyai banyak perpustakaan pihak ketiga, termasuk SQLX, GORM, dll. Ini memerlukan anda menganalisis situasi khusus anda dan memilih perpustakaan yang paling sesuai untuk kegunaan anda.

Akhir sekali, saya harap anda dapat menyepadukan maklumat yang disediakan dalam artikel ini ke dalam projek MySQL anda yang seterusnya dan melancarkan kuasa Golang dan MySQL.

Atas ialah kandungan terperinci pertanyaan golang mysql. 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

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

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

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)

Apakah kelemahan debian openssl Apakah kelemahan debian openssl Apr 02, 2025 am 07:30 AM

OpenSSL, sebagai perpustakaan sumber terbuka yang digunakan secara meluas dalam komunikasi yang selamat, menyediakan algoritma penyulitan, kunci dan fungsi pengurusan sijil. Walau bagaimanapun, terdapat beberapa kelemahan keselamatan yang diketahui dalam versi sejarahnya, yang sebahagiannya sangat berbahaya. Artikel ini akan memberi tumpuan kepada kelemahan umum dan langkah -langkah tindak balas untuk OpenSSL dalam sistem Debian. Debianopenssl yang dikenal pasti: OpenSSL telah mengalami beberapa kelemahan yang serius, seperti: Kerentanan Pendarahan Jantung (CVE-2014-0160): Kelemahan ini mempengaruhi OpenSSL 1.0.1 hingga 1.0.1f dan 1.0.2 hingga 1.0.2 versi beta. Penyerang boleh menggunakan kelemahan ini untuk maklumat sensitif baca yang tidak dibenarkan di pelayan, termasuk kunci penyulitan, dll.

Bagaimana anda menggunakan alat PPROF untuk menganalisis prestasi GO? Bagaimana anda menggunakan alat PPROF untuk menganalisis prestasi GO? Mar 21, 2025 pm 06:37 PM

Artikel ini menerangkan cara menggunakan alat PPROF untuk menganalisis prestasi GO, termasuk membolehkan profil, mengumpul data, dan mengenal pasti kesesakan biasa seperti CPU dan isu memori.

Bagaimana anda menulis ujian unit di GO? Bagaimana anda menulis ujian unit di GO? Mar 21, 2025 pm 06:34 PM

Artikel ini membincangkan ujian unit menulis di GO, meliputi amalan terbaik, teknik mengejek, dan alat untuk pengurusan ujian yang cekap.

Perpustakaan apa yang digunakan untuk operasi nombor terapung di GO? Perpustakaan apa yang digunakan untuk operasi nombor terapung di GO? Apr 02, 2025 pm 02:06 PM

Perpustakaan yang digunakan untuk operasi nombor terapung dalam bahasa Go memperkenalkan cara memastikan ketepatannya ...

Bagaimana anda menggunakan ujian yang didorong oleh jadual di GO? Bagaimana anda menggunakan ujian yang didorong oleh jadual di GO? Mar 21, 2025 pm 06:35 PM

Artikel ini membincangkan menggunakan ujian yang didorong oleh jadual di GO, satu kaedah yang menggunakan jadual kes ujian untuk menguji fungsi dengan pelbagai input dan hasil. Ia menyoroti faedah seperti kebolehbacaan yang lebih baik, penurunan duplikasi, skalabiliti, konsistensi, dan a

Terangkan tujuan Pakej Refleksi Go. Bilakah anda akan menggunakan refleksi? Apakah implikasi prestasi? Terangkan tujuan Pakej Refleksi Go. Bilakah anda akan menggunakan refleksi? Apakah implikasi prestasi? Mar 25, 2025 am 11:17 AM

Artikel ini membincangkan pakej GO's Reflect, yang digunakan untuk manipulasi kod runtime, bermanfaat untuk siri, pengaturcaraan generik, dan banyak lagi. Ia memberi amaran tentang kos prestasi seperti pelaksanaan yang lebih perlahan dan penggunaan memori yang lebih tinggi, menasihati penggunaan yang bijak dan terbaik

Bagaimana anda menentukan kebergantungan dalam fail go.mod anda? Bagaimana anda menentukan kebergantungan dalam fail go.mod anda? Mar 27, 2025 pm 07:14 PM

Artikel ini membincangkan menguruskan kebergantungan modul Go melalui Go.Mod, meliputi spesifikasi, kemas kini, dan resolusi konflik. Ia menekankan amalan terbaik seperti versi semantik dan kemas kini biasa.

Apakah masalah dengan thread giliran di crawler colly go? Apakah masalah dengan thread giliran di crawler colly go? Apr 02, 2025 pm 02:09 PM

Masalah Threading Giliran di GO Crawler Colly meneroka masalah menggunakan Perpustakaan Colly Crawler dalam bahasa Go, pemaju sering menghadapi masalah dengan benang dan permintaan beratur. � ...

See all articles