>백엔드 개발 >Golang >Go에서 GORM을 사용하여 장소 및 관련 도시를 효율적으로 쿼리하려면 어떻게 해야 합니까?

Go에서 GORM을 사용하여 장소 및 관련 도시를 효율적으로 쿼리하려면 어떻게 해야 합니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-09 00:09:10956검색

How Can I Efficiently Query Places and Their Associated Towns Using GORM in Go?

GORM Golang ORM 연관: 연결된 도시로 장소 쿼리

GORM for Go에서는 도시와 장소 간의 관계 등 모델 간의 관계를 정의하는 것이 가능합니다. 장소를 쿼리할 때 관련 도시 정보도 검색하는 것이 바람직한 경우가 많습니다.

문제

도시와 장소를 나타내는 다음 구조체를 고려하세요.

type Place struct {
  ID          int
  Name        string
  Town        Town
}

type Town struct {
  ID   int
  Name string
}

두 개의 도시와 도시 중 하나와 관련된 두 개의 장소를 포함하는 간단한 데이터베이스의 경우 모든 장소를 쿼리하면 예상한 결과가 나오지 않을 수 있습니다. 관련 마을 정보가 있는 장소를 검색하는 대신 빈 마을 필드가 있는 일련의 장소를 받을 수도 있습니다.

해결책

장소 및 관련 마을 정보를 올바르게 쿼리하려면 TownID가 다음과 같아야 합니다. Place 구조체에서 외래 키로 지정됩니다.

type Place struct {
  ID          int
  Name        string
  TownID      int
  Town        Town
}

이를 처리하기 위해 여러 가지 접근 방식을 취할 수 있습니다. 쿼리:

접근 방법 1: 관련() 메서드 사용

places := []Place{}
db.Find(&places)
for i, _ := range places {
    db.Model(places[i]).Related(&places[i].Town)
}

이 접근 방식은 각 장소에 대한 추가 쿼리를 트리거하여 관련 도시를 검색하므로 결과적으로 n 1개의 문제.

접근 방법 2: 사용 사전 로드

선호되는 접근 방식은 관련 모델을 효율적으로 쿼리할 수 있는 사전 로드를 사용하는 것입니다.

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

이 접근 방식은 두 개의 쿼리만 트리거합니다. 하나는 모든 장소를 검색하고 다른 하나는 모든 장소를 검색합니다.

이 접근 방식을 사용하면 쿼리는 각 장소 개체에 연결된 도시 정보가 포함된 예상 결과를 반환합니다.

위 내용은 Go에서 GORM을 사용하여 장소 및 관련 도시를 효율적으로 쿼리하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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