>백엔드 개발 >Golang >리플렉션을 사용하여 가변 `Rows.Scan()` 함수를 호출하는 방법은 무엇입니까?

리플렉션을 사용하여 가변 `Rows.Scan()` 함수를 호출하는 방법은 무엇입니까?

DDD
DDD원래의
2024-11-30 12:51:12220검색

How to Use Reflection to Call a Variadic `Rows.Scan()` Function?

Reflection을 활용하여 Scan Variadic 함수를 호출하는 방법

데이터베이스 결과로 작업할 때 리플렉션을 사용하여 Rows.Scan() 함수를 호출해야 할 수도 있습니다. 그러나 이는 다양한 수의 포인터에 대한 함수 요구 사항으로 인해 어려울 수 있습니다. 이 기사에서는 이러한 요구 사항을 해결하는 실용적인 솔루션을 자세히 살펴보겠습니다.

리플렉션을 활용하여 데이터베이스 쿼리에서 얻은 값으로 슬라이스를 채우는 것이 목표입니다. 이 프로세스에는 열 수를 결정하고 데이터 포인트를 보관하기 위해 빈 인터페이스 조각을 할당하는 작업이 포함됩니다. 이 접근 방식은 해당 유형에 대한 사전 지식 없이 값을 처리하는 유연성을 제공합니다.

샘플 코드 및 구현

다음 코드는 이 접근 방식의 구현을 보여줍니다.

package main

import (
    "database/sql"
    "fmt"
    _ "github.com/lib/pq"
)

func main() {
    db, _ := sql.Open(
        "postgres",
        "user=postgres dbname=go_testing password=pass sslmode=disable",
    )

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

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

성공의 열쇠

성공의 열쇠 이 접근 방식은 두 개의 슬라이스를 사용하는 것입니다. 하나는 값을 저장하고 다른 하나는 각 값에 해당하는 포인터를 포함합니다. 포인터가 사용된 후 값 슬라이스가 데이터로 채워져 추가 처리를 위해 실제 데이터 포인트에 대한 액세스를 제공합니다.

리플렉션을 활용하여 코드에 유형이 다음과 같은 값을 처리할 수 있는 기능을 부여합니다. 사전에 알려지지 않았습니다. 이러한 유연성으로 인해 데이터베이스 상호 작용의 다양성과 재사용성이 향상됩니다.

위 내용은 리플렉션을 사용하여 가변 `Rows.Scan()` 함수를 호출하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.