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