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 중국어 웹사이트의 기타 관련 기사를 참조하세요!