pertanyaan golang mysql
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
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) } }
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) }
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!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



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.

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.

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

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

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

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

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.

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. � ...
