>백엔드 개발 >Golang >SQLx를 사용하여 중첩된 구조체를 성공적으로 검색하려면 어떻게 해야 합니까?

SQLx를 사용하여 중첩된 구조체를 성공적으로 검색하려면 어떻게 해야 합니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-22 12:11:14979검색

How Can I Successfully Scan Nested Structs Using SQLx?

SQLx를 사용한 중첩 구조체 스캔

SQLx를 사용하여 쿼리 결과를 중첩 구조체로 스캔하려고 하면 사용자에게 대상 이름 누락과 같은 오류가 발생할 수 있습니다. 이 문제는 구조체 필드 이름과 데이터베이스 열 이름이 정확하게 일치하지 않을 때 발생합니다.

해결책: 중첩 구조체 삽입

SQLx 문서에서 제안된 대로 올바른 접근 방식은 중첩 구조체를 삽입하는 것입니다. 상위 구조체 내에서. 예를 들면 다음과 같습니다.

type Customer struct {
   Id     int    `json:"id" db:"id"`
   Name   string `json:"name" db:"name"`
   Address
}

type Address struct {
   Street string `json:"street" db:"street"`
   City   string `json:"city" db:"city"`
}

이 예에서는 Address 구조체가 Customer 구조체 내에 포함되어 있습니다. 중첩된 구조체를 포함하면 주소와 연결된 필드 이름과 태그가 고객으로 승격됩니다. 결과적으로 SQLx는 결과를 적절한 필드에 올바르게 매핑할 수 있습니다.

필드 중복 방지

중첩된 구조체를 포함하면 JSON 마샬링 중에 출력이 평면화된다는 점에 유의하는 것이 중요합니다. 원래 중첩 구조를 유지하려면 데이터베이스 구조를 원래 유형으로 다시 매핑할 수 있습니다. 또는 쿼리 결과를 map[string]인터페이스{}로 스캔할 수 있지만 이를 위해서는 Go에서 Postgres 데이터 유형을 주의 깊게 처리해야 합니다.

결론

이러한 지침을 따르면 결과는 SQLx를 사용하여 중첩된 구조체로 생성됩니다. 중첩된 구조체를 적절하게 포함하거나 지도를 다시 매핑하거나 스캔하는 등의 대체 접근 방식을 활용하면 데이터베이스에서 복잡한 데이터 구조를 효과적으로 추출할 수 있습니다.

위 내용은 SQLx를 사용하여 중첩된 구조체를 성공적으로 검색하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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