


Panduan sambungan pangkalan data bahasa Go: bimbing anda langkah demi langkah untuk melaksanakan operasi pangkalan data
Bahasa Go ialah bahasa pengaturcaraan yang agak mesra pemula yang ringkas, cekap dan mudah dipelajari. Sebagai pembangun, menyambung dan beroperasi dengan pangkalan data adalah bahagian penting dalam kerja harian kami. Dalam artikel ini, saya akan menunjukkan kepada anda cara menyambung ke pangkalan data menggunakan bahasa Go dan memberikan beberapa contoh kod khusus.
Pertama, kita perlu mengimport pemacu pangkalan data bahasa Go. Pada masa ini, bahasa Go menyokong pelbagai pangkalan data, seperti MySQL, SQLite, PostgreSQL, dll. Anda boleh memilih pemandu yang sesuai berdasarkan keperluan anda. Dalam artikel ini, kami mengambil MySQL sebagai contoh.
Pertama, kita perlu mengimport pakej pemacu MySQL dalam projek bahasa Go. Anda boleh menambah kod berikut pada fail go.mod:
require github.com/go-sql-driver/mysql v1.7.0
Kemudian, kami boleh mewujudkan sambungan dengan pangkalan data MySQL melalui kod berikut:
import ( "database/sql" _ "github.com/go-sql-driver/mysql" ) func main() { // 数据库连接信息 username := "root" password := "123456" host := "127.0.0.1" port := "3306" database := "example" // 建立数据库连接 connectionString := fmt.Sprintf("%s:%s@tcp(%s:%s)/%s?charset=utf8&parseTime=True&loc=Local", username, password, host, port, database) db, err := sql.Open("mysql", connectionString) if err != nil { log.Fatal(err) } defer db.Close() }
Dalam kod di atas, kami menggunakan fungsi database/sql
包和github.com/go-sql-driver/mysql
包。sql.Open()
函数用于建立与MySQL数据库的连接,其中第一个参数是驱动名称,第二个参数是连接字符串。如果连接数据库时发生错误,我们将使用log.Fatal()
untuk mencetak maklumat ralat dan keluar dari program.
Setelah sambungan ke pangkalan data berjaya diwujudkan, kami boleh melakukan pelbagai operasi pangkalan data. Berikut adalah beberapa contoh operasi pangkalan data yang biasa:
- Query Data:
rows, err := db.Query("SELECT * FROM users") if err != nil { log.Fatal(err) } defer rows.Close() for rows.Next() { var id int var name string err := rows.Scan(&id, &name) if err != nil { log.Fatal(err) } fmt.Println(id, name) }
- insert Data:
stmt, err := db.Prepare("INSERT INTO users (name) VALUES (?)") if err != nil { log.Fatal(err) } defer stmt.Close() res, err := stmt.Exec("John") if err != nil { log.Fatal(err) } lastID, err := res.LastInsertId() if err != nil { log.Fatal(err) } fmt.Println("Inserted ID:", lastID)
- update Data:
stmt, err := db.Prepare("UPDATE users SET name = ? WHERE id = ?") if err != nil { log.Fatal(err) } defer stmt.Close() res, err := stmt.Exec("John Doe", 1) if err != nil { log.Fatal(err) } affectedRows, err := res.RowsAffected() if err != nil { log.Fatal(err) } fmt.Println("Affected Rows:", affectedRows)
- delete Data:
stmt, err := db.Prepare("DELETE FROM users WHERE id = ?") if err != nil { log.Fatal(err) } defer stmt.Close() res, err := stmt.Exec(1) if err != nil { log.Fatal(err) } affectedRows, err := res.RowsAffected() if err != nil { log.Fatal(err) } fmt.Println("Affected Rows:", affectedRows)
The di atas adalah beberapa pangkalan data asas Contoh operasi. Dalam pembangunan sebenar, anda mungkin memerlukan pertanyaan yang lebih kompleks dan pemprosesan transaksi. Walau bagaimanapun, melalui contoh di atas, anda telah pun memahami cara menggunakan bahasa Go untuk menyambung ke pangkalan data dan melaksanakan beberapa operasi pangkalan data biasa.
Untuk meringkaskan, artikel ini memperkenalkan secara terperinci cara menggunakan bahasa Go untuk menyambung ke pangkalan data MySQL dan memberikan beberapa contoh kod khusus. Saya harap ini akan membantu anda menyambung dan beroperasi dengan pangkalan data dalam pembangunan bahasa Go. Jika anda mempunyai sebarang pertanyaan atau kekeliruan, anda boleh tinggalkan mesej di bawah dan saya akan cuba sedaya upaya untuk menjawabnya. Saya mengucapkan selamat belajar dan menulis kod bahasa Go yang elegan dan cekap!
Atas ialah kandungan terperinci Panduan sambungan pangkalan data bahasa Go: bimbing anda langkah demi langkah untuk melaksanakan operasi pangkalan data. 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

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

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





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

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

Perbezaan antara percetakan rentetan dalam bahasa Go: perbezaan kesan menggunakan fungsi println dan rentetan () sedang ...

Masalah menggunakan redisstream untuk melaksanakan beratur mesej dalam bahasa Go menggunakan bahasa Go dan redis ...

Dua cara untuk menentukan struktur dalam bahasa Go: perbezaan antara VAR dan jenis kata kunci. Apabila menentukan struktur, pergi bahasa sering melihat dua cara menulis yang berbeza: pertama ...

Apa yang perlu saya lakukan jika label struktur tersuai di Goland tidak dipaparkan? Apabila menggunakan Goland untuk Pembangunan Bahasa GO, banyak pemaju akan menghadapi tag struktur tersuai ...

Perpustakaan mana yang dibangunkan oleh syarikat besar atau projek sumber terbuka yang terkenal? Semasa pengaturcaraan di GO, pemaju sering menghadapi beberapa keperluan biasa, ...

Apabila menggunakan SQL.Open, mengapa DSN tidak melaporkan ralat? Dalam bahasa Go, sql.open ...
