Rumah pembangunan bahagian belakang Golang Bagaimana untuk Memanggil Variadic Rows.Scan() Secara Dinamik Menggunakan Reflection in Go?

Bagaimana untuk Memanggil Variadic Rows.Scan() Secara Dinamik Menggunakan Reflection in Go?

Dec 04, 2024 am 12:58 AM

How to Dynamically Call Variadic Rows.Scan() Using Reflection in Go?

Memanggil Fungsi Variadik dengan Refleksi untuk Imbasan SQL

Apabila menggunakan fungsi Rows.Scan() untuk pertanyaan pangkalan data SQL, ia menjadi perlu untuk gunakan refleksi untuk mengambil kira bilangan pembolehubah penunjuk yang diterimanya. Ini membolehkan hirisan mengisi secara dinamik dengan data daripada hasil pertanyaan.

Langkah untuk Mengimbas Secara Dinamik Menggunakan Refleksi

Untuk memanggil fungsi variadik seperti Rows.Scan() menggunakan pantulan , ikuti langkah berikut:

  1. Dapatkan Lajur Maklumat: Gunakan rows.Columns() untuk mendapatkan semula nama lajur.
  2. Buat Slices: Buat dua keping: satu untuk nilai (nilai) dan satu forpointer (valuePtrs), kedua-duanya sepadan dengan panjang lajur.
  3. Imbas Data: Dalam gelung untuk setiap baris dalam set hasil, lelaran pada setiap lajur dan tetapkan penunjuk kepada keping valuePtrs. Kemudian, panggil baris.Scan(valuePtrs...).
  4. Dapatkan Nilai: Selepas mengimbas, data akan tersedia dalam kepingan nilai. Tukar []bait kepada rentetan jika perlu.

Contoh Kod

Coretan kod berikut menunjukkan cara mengimbas secara dinamik menggunakan pantulan:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

package main

 

import (

    "fmt"

    _ "github.com/lib/pq"

    "database/sql"

)

 

func main() {

    db, _ := sql.Open("postgres", "connection_string")

    rows, _ := db.Query("SELECT * FROM my_table")

 

    columns, _ := rows.Columns()

    count := len(columns)

    values := make([]interface{}, count)

    valuePtrs := make([]interface{}, count)

 

    for rows.Next() {

        for i := range columns {

            valuePtrs[i] = &values[i]

        }

        rows.Scan(valuePtrs...)

        for i, col := range columns {

            val := values[i]

            b, ok := val.([]byte)

            var v interface{}

            if ok {

                v = string(b)

            } else {

                v = val

            }

            fmt.Println(col, v)

        }

    }

}

Salin selepas log masuk

Dengan melaksanakan kaedah ini, anda boleh mengisi kepingan secara dinamik dengan hasil pertanyaan tanpa menyatakan jenis data dalam terlebih dahulu.

Atas ialah kandungan terperinci Bagaimana untuk Memanggil Variadic Rows.Scan() Secara Dinamik Menggunakan Reflection in 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

Tag artikel 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)

GO Language Pack Import: Apakah perbezaan antara garis bawah dan tanpa garis bawah? GO Language Pack Import: Apakah perbezaan antara garis bawah dan tanpa garis bawah? Mar 03, 2025 pm 05:17 PM

GO Language Pack Import: Apakah perbezaan antara garis bawah dan tanpa garis bawah?

Bagaimana saya menulis objek dan stub untuk ujian di GO? Bagaimana saya menulis objek dan stub untuk ujian di GO? Mar 10, 2025 pm 05:38 PM

Bagaimana saya menulis objek dan stub untuk ujian di GO?

Bagaimana untuk melaksanakan pemindahan maklumat jangka pendek antara halaman dalam kerangka beego? Bagaimana untuk melaksanakan pemindahan maklumat jangka pendek antara halaman dalam kerangka beego? Mar 03, 2025 pm 05:22 PM

Bagaimana untuk melaksanakan pemindahan maklumat jangka pendek antara halaman dalam kerangka beego?

Bagaimana saya boleh menggunakan alat pengesanan untuk memahami aliran pelaksanaan aplikasi saya? Bagaimana saya boleh menggunakan alat pengesanan untuk memahami aliran pelaksanaan aplikasi saya? Mar 10, 2025 pm 05:36 PM

Bagaimana saya boleh menggunakan alat pengesanan untuk memahami aliran pelaksanaan aplikasi saya?

Bagaimana saya boleh menentukan kekangan jenis tersuai untuk generik di GO? Bagaimana saya boleh menentukan kekangan jenis tersuai untuk generik di GO? Mar 10, 2025 pm 03:20 PM

Bagaimana saya boleh menentukan kekangan jenis tersuai untuk generik di GO?

Bagaimana cara menukar senarai hasil pertanyaan mysql ke dalam slice struktur tersuai dalam bahasa Go? Bagaimana cara menukar senarai hasil pertanyaan mysql ke dalam slice struktur tersuai dalam bahasa Go? Mar 03, 2025 pm 05:18 PM

Bagaimana cara menukar senarai hasil pertanyaan mysql ke dalam slice struktur tersuai dalam bahasa Go?

Bagaimana cara menulis fail dalam bahasa Go dengan mudah? Bagaimana cara menulis fail dalam bahasa Go dengan mudah? Mar 03, 2025 pm 05:15 PM

Bagaimana cara menulis fail dalam bahasa Go dengan mudah?

Bagaimanakah saya boleh menggunakan alat linter dan analisis statik untuk meningkatkan kualiti dan pemeliharaan kod pergi saya? Bagaimanakah saya boleh menggunakan alat linter dan analisis statik untuk meningkatkan kualiti dan pemeliharaan kod pergi saya? Mar 10, 2025 pm 05:38 PM

Bagaimanakah saya boleh menggunakan alat linter dan analisis statik untuk meningkatkan kualiti dan pemeliharaan kod pergi saya?

See all articles