>백엔드 개발 >Golang >Go SQL 행 인스턴스의 열 값을 []문자열로 추출하는 방법은 무엇입니까?

Go SQL 행 인스턴스의 열 값을 []문자열로 추출하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-11-12 10:22:01621검색

How to Extract Column Values from a Go SQL Rows Instance into a []string?

Go SQL 행 인스턴스를 사용하여 []string으로 열 값 추출

도전 과제:

많은 프로그래밍 작업에는 행 추출이 필요합니다. 데이터베이스 테이블의 데이터를 구조화된 형식으로 변환합니다. Go에서 데이터베이스/sql 패키지는 테이블 행을 반복하기 위한 Rows 인스턴스를 제공합니다. 그러나 행의 Scan 메서드는 알려진 유형의 대상 변수에 대한 포인터를 예상하므로 열의 수와 유형을 미리 알 수 없는 경우 어려울 수 있습니다.

해결책:

Rows 인스턴스의 열을 []문자열로 읽으려면 다음을 사용할 수 있습니다. 접근 방식:

  1. 열 이름 얻기: Rows.Columns()를 호출하여 열 이름 조각을 가져옵니다.
  2. 인터페이스 조각 만들기: 열 슬라이스와 길이가 같은 readCols라는 []인터페이스{} 슬라이스를 생성합니다. 이 조각은 문자열 변수의 주소를 보유합니다.
  3. 문자열 조각 만들기: 열 조각과 길이가 같은 writeCols라는 빈 []string 조각을 만듭니다. 이 조각은 문자열 값을 저장합니다.
  4. 주소 채우기: writeCols의 인덱스를 반복하고 readCols의 각 인덱스를 writeCols의 해당 요소 주소에 할당합니다.
  5. 행 스캔: Next() 및 Scan()을 사용하여 Rows 인스턴스를 반복합니다. readCols를 Scan()에 인수로 전달하면 writeCols의 문자열 주소가 채워집니다.
  6. 결과에 추가: writeCols의 값을 CSV와 같은 원하는 데이터 구조에 추가합니다. writer.

예:

package main

import (
    "fmt"
    "io"

    "database/sql"
)

func dumpTable(rows *sql.Rows, out io.Writer) error {
    colNames, err := rows.Columns()
    if err != nil {
        return err
    }

    writer := csv.NewWriter(out)
    writer.Comma = '\t'

    readCols := make([]interface{}, len(colNames))
    writeCols := make([]string, len(colNames))
    for i, _ := range writeCols {
        readCols[i] = &writeCols[i]
    }

    for rows.Next() {
        err := rows.Scan(readCols...)
        if err != nil {
            return err
        }
        writer.Write(writeCols)
    }

    if err = rows.Err(); err != nil {
        return err
    }

    writer.Flush()
    return nil
}

이 코드를 사용하면 Rows 인스턴스에서 열을 읽고 추가 처리를 위해 []문자열로 변환할 수 있습니다. .

위 내용은 Go SQL 행 인스턴스의 열 값을 []문자열로 추출하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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