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 }
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) }
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!