> 백엔드 개발 > Golang > GORM의 사전 로드 기능은 어떻게 연관이 있는 쿼리를 최적화할 수 있습니까?

GORM의 사전 로드 기능은 어떻게 연관이 있는 쿼리를 최적화할 수 있습니까?

DDD
풀어 주다: 2024-12-10 02:47:09
원래의
176명이 탐색했습니다.

How Can GORM's Preload Function Optimize Queries with Associations?

GORM Golang ORM 연결

Go에서 GORM은 데이터베이스와 상호 작용하는 데 널리 사용되는 ORM입니다. GORM에서 연관을 사용하여 작업할 때 구조체 간의 적절한 관계를 설정하는 것이 중요합니다. 도시와 장소를 나타내는 다음 구조체를 고려하세요.

type Place struct {
    ID          int
    Name        string
    Town        Town
}

type Town struct {
    ID   int
    Name string
}
로그인 후 복사

여기서 각 마을은 여러 장소를 가질 수 있지만 각 장소는 하나의 마을에만 속합니다.

모든 장소를 쿼리한다고 가정해 보세요. 및 관련 타운 정보. 다음은 샘플 데이터베이스와 예상 결과입니다.

Places Table

id name town_id
1 Place1 1
2 Place2 1

Towns Table

id name
1 Town1

예상 결과:

id name Town
1 Place1 Town1
2 Place2 Town1

초기 구현

초기 구현에서 모든 장소를 쿼리하려고 시도했지만 관련 도시 정보를 포함하지 못했습니다.

db, _ := gorm.Open("sqlite3", "./data.db")
defer db.Close()

places := []Place{}
db.Find(&places)
fmt.Println(places)
로그인 후 복사

사전 로드 사용

최적의 솔루션은 Find 작업 전에 GORM의 Preload 방법을 사용하는 것입니다. 이렇게 하면 관련 데이터가 기본 쿼리에 포함되어 추가 쿼리가 필요하지 않습니다.

db.Preload("Town").Find(&places)
로그인 후 복사

이 접근 방식을 사용하면 두 개의 쿼리만 트리거되어 성능이 크게 향상됩니다.

쿼리 로그:

Time Query
22.24ms SELECT * FROM "places"
0.92ms SELECT * FROM "towns" WHERE "id" in ('1')

결론

협회와 협력할 때 GORM, 외래 키를 올바르게 정의하는 것이 중요합니다. 사전 로드를 활용하면 쿼리에 관련 정보를 효율적으로 포함시켜 확장성을 유지하고 성능을 최적화할 수 있습니다.

위 내용은 GORM의 사전 로드 기능은 어떻게 연관이 있는 쿼리를 최적화할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿