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