>백엔드 개발 >Golang >GORM의 사전 로드 기능은 어떻게 Go에서 관련 레코드를 효율적으로 가져올 수 있습니까?

GORM의 사전 로드 기능은 어떻게 Go에서 관련 레코드를 효율적으로 가져올 수 있습니까?

Barbara Streisand
Barbara Streisand원래의
2024-12-10 18:13:14506검색

How Can GORM's Preload Function Efficiently Fetch Related Records in Go?

GORM Golang ORM 연결: 관련 레코드 사전 로드

GORM은 데이터베이스 작업을 단순화하는 인기 있는 Go용 ORM입니다. ORM으로 작업할 때 관련 레코드 간의 연결을 관리하는 것이 필수적입니다. 이러한 맥락에서 GORM의 사전 로드 기능을 사용하여 관련 레코드를 효율적으로 검색하는 방법을 살펴보겠습니다.

Place와 Town이라는 두 개의 구조체가 있는 시나리오를 고려해 보겠습니다. 각 장소는 단일 타운에 속하며 각 타운에는 여러 장소가 있습니다.

type Place struct {
  ID          int
  Name        string
  Town        Town
}

type Town struct {
  ID   int
  Name string
}

모든 장소를 가져오고 각 장소에 해당하는 타운을 즉시 로드하려면 다음과 같이 사전 로드 기능을 사용할 수 있습니다.

db.Preload("Town").Find(&places)

이 한 줄의 코드는 두 개의 쿼리를 실행합니다. 하나는 모든 장소를 가져오는 쿼리이고 다른 하나는 일치하는 장소가 있는 모든 마을을 가져오는 쿼리입니다. Place 구조체의 결과 조각에는 Town 필드가 채워집니다.

fmt.Println(places)
// Output: [{1 Place1  {1 Town1}} {2 Place2  {1 Town1}}]

이 접근 방식은 관련 레코드를 검색하기 위해 N개의 추가 쿼리를 실행해야 할 때 발생하는 N 1 문제를 방지하므로 효율적입니다. 사전 로드를 사용하면 단 두 번의 쿼리로 필요한 모든 데이터를 검색할 수 있으므로 대규모 데이터 세트에 대해 더 효율적입니다.

위 내용은 GORM의 사전 로드 기능은 어떻게 Go에서 관련 레코드를 효율적으로 가져올 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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