Heim > Backend-Entwicklung > Golang > Wie lese ich SELECT *-Spalten in einen []String in Go ein?

Wie lese ich SELECT *-Spalten in einen []String in Go ein?

Barbara Streisand
Freigeben: 2024-11-10 20:30:03
Original
323 Leute haben es durchsucht

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

Komplexität beim Einlesen von SELECT *-Spalten in []string in Go

Eine häufige Aufgabe bei der Datenverarbeitung besteht darin, Zeilen aus einer Datenbanktabelle abzurufen und speichern Sie sie in einem praktischen Format. In Go können Sie das Paket „database/sql“ verwenden, um eine Schnittstelle zu Datenbanken herzustellen. Allerdings kann es eine Herausforderung darstellen, auf eine variable Anzahl von Spalten mit unbekannten Typen zu stoßen.

Der Typ „sql.Rows“ bietet Zugriff auf die Ergebnisse einer Abfrage, seine Scan-Methode erwartet jedoch, dass typisierte Felder ausgefüllt werden. Das direkte Konvertieren der Werte in einen String-Slice ([]string) ist nicht einfach.

Lösung: Verwendung eines Interface-Slices

Um dieses Problem zu beheben, müssen Sie einen erstellen ein Interface-Slice ([]interface{}), das auf jede Zeichenfolge in Ihrem String-Slice zeigt. Dazu gehört die Zuweisung eines temporären Slice und das Festlegen jedes Elements so, dass es auf das entsprechende Element im String-Slice zeigt.

Beispielcode:

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
}
Nach dem Login kopieren

Sobald das Interface-Slice vorhanden ist vorbereitet, können Sie damit die Zeilen scannen.

Zeilen scannen und in Strings konvertieren

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)
}
Nach dem Login kopieren

Mit diesem Ansatz können Sie die Spaltenwerte direkt in a einlesen String-Slice, das die variable Anzahl und Typen von Spalten berücksichtigt.

Das obige ist der detaillierte Inhalt vonWie lese ich SELECT *-Spalten in einen []String in Go ein?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage