>백엔드 개발 >Golang >소속 관계에 대해 Gorm에서 외래 키를 올바르게 구현하는 방법은 무엇입니까?

소속 관계에 대해 Gorm에서 외래 키를 올바르게 구현하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-19 00:01:02620검색

How to Correctly Implement Foreign Keys in Gorm for a Belongs-To Relationship?

Gorm 관계 오류: 외래 키의 올바른 구현

Gorm에서는 효율적인 데이터 검색 및 조작을 위해 모델 간의 관계 설정이 중요합니다. 최근 보고된 문제는 특히 "위치" 필드가 외래 키로 사용될 때 데이터베이스에서 데이터를 검색하는 동안 발생한 오류에 관한 것입니다.

문제를 이해하려면 먼저 정의된 데이터 모델을 검토해 보겠습니다. 관계에 대해:

// LocationDescription model
type LocationDescription struct {
    ID       int    `json:"locationID"`
    Name     string `json:"name"`
    IsActive bool   `json:"isActive"`
}

// ConfigurationDescription model
type ConfigurationDescription struct {
    ID         int                 `json:"configurationID"`
    Name       string              `json:"name"`
    IsActive   bool                `json:"isActive"`
    LocationID int                 `json:"location_id"`
    Location   LocationDescription `json:"location,omitempty" gorm:"foreignKey:ID;references:LocationID"`
}

"구조 모델에 대한 잘못된 필드가 발견되었습니다.ConfigurationDescription의 필드 위치, 관계에 대해 유효한 외래 키를 정의해야 합니다."라는 오류가 발생하면 Gorm이 " Location" 필드를 "LocationDescription" 테이블의 기본 키로 바꿉니다. 코드를 검토한 결과 "foreignKey" 및 "references" 태그가 잘못 적용된 것이 분명합니다.

Belongs-To 관계의 경우 "foreignKey"는 참조하는 모델-로컬 키 필드를 지정해야 합니다. 외국 엔터티의 기본 키 또는 고유 키입니다. 이 경우 외부 엔터티는 "LocationDescription"이고 기본 키는 "ID"입니다. 따라서 적절한 구성은 다음과 같습니다.

    Location   LocationDescription `json:"location,omitempty" gorm:"foreignKey:LocationID;references:ID"`

이 조정을 수행한 후에는 Gorm 오류가 해결되어 데이터베이스에서 데이터를 성공적으로 검색할 수 있습니다. 모델 간의 적절한 관계를 설정하려면 외래 키와 참조가 올바르게 정의되었는지 확인하는 것이 중요합니다.

위 내용은 소속 관계에 대해 Gorm에서 외래 키를 올바르게 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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