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