Rumah > pembangunan bahagian belakang > Golang > Bagaimana untuk Membaca SELECT * Lajur ke dalam rentetan [] dalam Go?

Bagaimana untuk Membaca SELECT * Lajur ke dalam rentetan [] dalam Go?

Barbara Streisand
Lepaskan: 2024-11-10 20:30:03
asal
332 orang telah melayarinya

How to Read SELECT * Columns into a []string in Go?

Kerumitan Pembacaan SELECT * Lajur ke dalam []rentetan dalam Go

Tugas biasa dalam pemprosesan data adalah untuk mendapatkan semula baris daripada jadual pangkalan data dan simpannya dalam format yang mudah. Dalam Go, anda boleh menggunakan pakej pangkalan data/sql untuk antara muka dengan pangkalan data. Walau bagaimanapun, menghadapi bilangan lajur yang berubah-ubah dengan jenis yang tidak diketahui boleh menimbulkan cabaran.

Jenis sql.Rows menyediakan akses kepada hasil pertanyaan, tetapi kaedah Imbasannya menjangkakan medan yang ditaip akan diisi. Menukar nilai kepada sekeping rentetan ([]rentetan) secara langsung adalah tidak mudah.

Penyelesaian: Menggunakan Slice Antara Muka

Untuk menangani isu ini, anda mesti mencipta hirisan antara muka ([]antara muka{}) yang menunjuk kepada setiap rentetan dalam hirisan rentetan anda. Ini melibatkan memperuntukkan kepingan sementara dan menetapkan setiap elemen untuk menghala ke elemen yang sepadan dalam kepingan rentetan.

Kod Contoh:

rawResult := make([][]byte, len(cols))
result := make([]string, len(cols))

dest := make([]interface{}, len(cols)) // A temporary interface{} slice
for i, _ := range rawResult {
    dest[i] = &rawResult[i] // Put pointers to each string in the interface slice
}
Salin selepas log masuk

Sebaik sahaja kepingan antara muka disediakan, anda boleh menggunakannya untuk mengimbas baris.

Mengimbas Baris dan Menukar kepada Rentetan

for rows.Next() {
    err = rows.Scan(dest...)
    if err != nil {
        fmt.Println("Failed to scan row", err)
        return
    }

    for i, raw := range rawResult {
        if raw == nil {
            result[i] = "\N"
        } else {
            result[i] = string(raw)
        }
    }

    fmt.Printf("%#v\n", result)
}
Salin selepas log masuk

Pendekatan ini membolehkan anda membaca terus nilai lajur ke dalam kepingan rentetan, menampung nombor pembolehubah dan jenis lajur.

Atas ialah kandungan terperinci Bagaimana untuk Membaca SELECT * Lajur ke dalam rentetan [] dalam Go?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan