Rumah pembangunan bahagian belakang Golang Tanya pangkalan data Menggunakan Go

Tanya pangkalan data Menggunakan Go

Aug 16, 2024 am 07:06 AM

Query a database Using Go

Langkah 1: Pasang pemacu MySQL
Pertama, anda perlu memasang pemacu MySQL untuk Go. Yang popular ialah go-sql-driver/mysql. Anda boleh memasangnya menggunakan:

go get -u github.com/go-sql-driver/mysql

Langkah 2: Tulis kod Go
Berikut ialah contoh cara anda boleh menyambung ke pangkalan data MySQL dan data pertanyaan:

package main

import (
    "database/sql"
    "fmt"
    "log"

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

func main() {
    // Open the database connection
    db, err := sql.Open("mysql", "username:password@tcp(127.0.0.1:3306)/dbname")
    if err != nil {
        log.Fatal(err)
    }
    defer db.Close()

    // Ping the database to check if the connection is alive
    if err := db.Ping(); err != nil {
        log.Fatal(err)
    }

    // Define the query
    query := "SELECT id, name FROM users WHERE active = ?"
    active := true

    // Execute the query
    rows, err := db.Query(query, active)
    if err != nil {
        log.Fatal(err)
    }
    defer rows.Close()

    // Iterate through the result set
    for rows.Next() {
        var id int
        var name string
        if err := rows.Scan(&id, &name); err != nil {
            log.Fatal(err)
        }
        fmt.Printf("ID: %d, Name: %s\n", id, name)
    }

    // Check for errors from iterating over rows
    if err := rows.Err(); err != nil {
        log.Fatal(err)
    }
}

Penjelasan:
Import pakej yang diperlukan: Anda mengimport pakej pangkalan data/sql untuk interaksi pangkalan data dan pemacu MySQL (github.com/go-sql-driver/mysql).

Buka sambungan pangkalan data: Anda membuka sambungan ke pangkalan data menggunakan sql.Open. Format rentetan sambungan ialah nama pengguna:password@tcp(host:port)/dbname.

Ping pangkalan data: Amalan yang baik untuk ping pangkalan data untuk memastikan sambungan diwujudkan.

Laksanakan pertanyaan: Anda laksanakan pertanyaan menggunakan db.Query. Kaedah Pertanyaan mengembalikan objek *sql.Rows, yang boleh anda ulangi untuk mendapatkan set hasil.

Lelaran melalui hasil: Anda menggunakan gelung untuk melelakan melalui baris dan Imbas setiap baris ke dalam pembolehubah.

Kendalikan ralat: Anda harus mengendalikan sebarang ralat yang berlaku semasa pelaksanaan pertanyaan atau semasa lelaran.

Langkah 3: Jalankan kod anda
Pastikan anda menggantikan nama pengguna, kata laluan, 127.0.0.1:3306 dan nama db dengan bukti kelayakan MySQL dan butiran pangkalan data sebenar anda.

Jalankan program Go anda, dan ia akan mengeluarkan hasil pertanyaan anda.

Contoh ini boleh disesuaikan untuk pangkalan data lain dengan menukar pemacu dan rentetan sambungan dengan sewajarnya.

Atas ialah kandungan terperinci Tanya pangkalan data Menggunakan Go. 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

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

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.

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

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

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)

Topik panas

Tutorial PHP
1511
276
Pergi untuk pemprosesan audio/video Pergi untuk pemprosesan audio/video Jul 20, 2025 am 04:14 AM

Inti pemprosesan audio dan video terletak pada pemahaman proses asas dan kaedah pengoptimuman. 1. Proses asas termasuk pengambilalihan, pengekodan, penghantaran, penyahkodan dan main balik, dan setiap pautan mempunyai kesukaran teknikal; 2. Masalah biasa seperti penyimpangan audio dan video, kelewatan lag, bunyi bunyi, gambar kabur, dan lain -lain boleh diselesaikan melalui pelarasan segerak, pengoptimuman pengekodan, modul pengurangan hingar, pelarasan parameter, dan sebagainya; 3. Adalah disyorkan untuk menggunakan FFMPEG, OpenCV, WebRTC, GSTREAMER dan alat lain untuk mencapai fungsi; 4. Dari segi pengurusan prestasi, kita harus memberi perhatian kepada pecutan perkakasan, penetapan kadar bingkai resolusi yang munasabah, masalah konvensyen dan masalah kebocoran memori. Menguasai perkara utama ini akan membantu meningkatkan kecekapan pembangunan dan pengalaman pengguna.

Membangunkan pengendali Kubernet di mana sahaja Membangunkan pengendali Kubernet di mana sahaja Jul 25, 2025 am 02:38 AM

Cara yang paling berkesan untuk menulis Kubernetesoperator adalah untuk menggunakan Go untuk menggabungkan Kubebuilder dan pengawal-runtime. 1. Memahami corak pengendali: Tentukan sumber tersuai melalui CRD, tulis pengawal untuk mendengar perubahan sumber dan lakukan gelung perdamaian untuk mengekalkan keadaan yang diharapkan. 2. Gunakan Kubebuilder untuk memulakan projek dan membuat API untuk menghasilkan CRD, pengawal dan konfigurasi secara automatik. 3. Tentukan spec dan struktur status CRD dalam API/V1/MYAPP_TYPES.GO, dan menjalankan makeManifests untuk menjana cRDYAML. 4. Daftar masuk dalam pengawal

Teknik Pengoptimuman Permintaan Pergi untuk PostgreSQL/MySQL Teknik Pengoptimuman Permintaan Pergi untuk PostgreSQL/MySQL Jul 19, 2025 am 03:56 AM

TooptimizegoapplicationsInteractingWithPostgreSqlormysql, focusonindexing, selectivequeries, connectionhandling, caching, andormefficiency.1) useproperIndexing-identifyfrequeriedcolumns, addIndExessely, andusecompositeindexesformultifulty-columnuerformultiulti

Pergi untuk perpustakaan manipulasi imej Pergi untuk perpustakaan manipulasi imej Jul 21, 2025 am 12:23 AM

Perpustakaan pemprosesan imej yang biasa termasuk pakej imej perpustakaan standard dan perpustakaan pihak ketiga, seperti pengimejan, bimg, dan imagick. 1. Pakej imej sesuai untuk operasi asas; 2. Pencitraan mempunyai fungsi lengkap dan API mudah, yang sesuai untuk kebanyakan keperluan; 3. BIMG didasarkan pada libvips, mempunyai prestasi yang kuat, yang sesuai untuk imej besar atau kesesuaian yang tinggi; 4. Imagick mengikat Imagemagick, yang berkuasa tetapi mempunyai ketergantungan yang berat. Cepat melaksanakan skala imej dan penanaman. Anda boleh menggunakan perpustakaan pengimejan untuk menyelesaikannya melalui beberapa baris kod dalam saiz semula dan fungsi cropanchor, dan menyokong konfigurasi parameter berganda. Menambah penapis atau nada penyesuaian dapat dicapai melalui fungsi transformasi warna yang disediakan oleh imaginasi, seperti graysc

Bagaimana untuk pulih dari panik dalam perjalanan? Bagaimana untuk pulih dari panik dalam perjalanan? Jul 23, 2025 am 04:11 AM

Panik adalah seperti program "serangan jantung" di Go. Pulih boleh digunakan sebagai "alat pertolongan cemas" untuk mencegah kemalangan, tetapi pulih hanya berkuatkuasa dalam fungsi penangguhan. 1.Recover digunakan untuk mengelakkan kelewatan perkhidmatan, log log, dan kesilapan yang mesra. 2. Ia mesti digunakan bersempena dengan menangguhkan dan hanya berkuatkuasa pada goroutine yang sama. Program ini tidak kembali ke titik panik selepas pemulihan. 3. Adalah disyorkan untuk menggunakannya di peringkat atas atau pintu masuk kritikal, dan tidak menyalahgunakannya, dan memberi keutamaan untuk menggunakan pemprosesan ralat. 4. Corak umum adalah untuk merangkum fungsi Saferun untuk membungkus logik panik yang mungkin. Hanya dengan menguasai senario penggunaannya dan batasan boleh memainkan peranannya dengan betul.

Peruntukan timbunan vs timbunan dengan petunjuk di Go Peruntukan timbunan vs timbunan dengan petunjuk di Go Jul 23, 2025 am 04:14 AM

Peruntukan Stack sesuai untuk pembolehubah tempatan kecil dengan kitaran hayat yang jelas, dan diuruskan secara automatik, dengan kelajuan yang cepat tetapi banyak sekatan; Peruntukan timbunan digunakan untuk data dengan kitaran hayat yang panjang atau tidak pasti, dan fleksibel tetapi mempunyai kos prestasi. Pengkompil GO secara automatik menentukan kedudukan peruntukan pembolehubah melalui analisis melarikan diri. Jika pembolehubah boleh melarikan diri dari skop fungsi semasa, ia akan diperuntukkan kepada timbunan. Situasi biasa yang menyebabkan melarikan diri termasuk: mengembalikan penunjuk pembolehubah tempatan, memberikan nilai kepada jenis antara muka, dan lulus dalam goroutine. Hasil analisis melarikan diri dapat dilihat melalui -gcflags = " -m". Apabila menggunakan petunjuk, anda harus memberi perhatian kepada kitaran hidup yang berubah -ubah untuk mengelakkan pelarian yang tidak perlu.

Pergi dengan contoh contoh pembalakan middleware http Pergi dengan contoh contoh pembalakan middleware http Aug 03, 2025 am 11:35 AM

HTTP Log Middleware di GO boleh merakam kaedah permintaan, laluan, IP klien dan memakan masa. 1. Gunakan http.handlerfunc untuk membungkus pemproses, 2. Rekod waktu mula dan masa akhir sebelum dan selepas memanggil next.servehttp, 3. Dapatkan IP pelanggan sebenar melalui r.remoteaddr dan X-forward-for headers, 4. Gunakan log.printf untuk mengeluarkan log permintaan, 5. Kod sampel lengkap telah disahkan untuk dijalankan dan sesuai untuk memulakan projek kecil dan sederhana. Cadangan lanjutan termasuk menangkap kod status, menyokong log JSON dan meminta penjejakan ID.

Pergi untuk pengkomputeran saintifik dan analisis berangka Pergi untuk pengkomputeran saintifik dan analisis berangka Jul 23, 2025 am 01:53 AM

GO Language boleh digunakan untuk pengiraan saintifik dan analisis berangka, tetapi perlu difahami. Kelebihannya terletak pada sokongan dan prestasi konkurensi, yang sesuai untuk algoritma selari seperti penyelesaian yang diedarkan, simulasi Monte Carlo, dan sebagainya; Perpustakaan komuniti seperti gonum dan MAT64 menyediakan fungsi pengiraan numerik asas; Pengaturcaraan hibrid boleh digunakan untuk memanggil C/C dan Python melalui CGO atau antara muka untuk meningkatkan kepraktisan. Batasannya adalah bahawa ekosistem tidak matang seperti python, visualisasi dan alat lanjutan lebih lemah, dan beberapa dokumen perpustakaan tidak lengkap. Adalah disyorkan untuk memilih senario yang sesuai berdasarkan ciri GO dan merujuk kepada contoh kod sumber untuk menggunakannya secara mendalam.

See all articles