>  기사  >  백엔드 개발  >  겉보기에 올바른 모델 관계에도 불구하고 Gorm이 외래 키 오류를 발생시키는 이유는 무엇입니까?

겉보기에 올바른 모델 관계에도 불구하고 Gorm이 외래 키 오류를 발생시키는 이유는 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-11-22 12:24:15178검색

Why Does Gorm Throw a Foreign Key Error Despite Seemingly Correct Model Relationships?

Gorm 관계의 외래 키 오류

Gorm을 사용하여 데이터베이스에서 모델을 검색하려고 시도하는 동안 "잘못된 필드"라는 오류 메시지가 나타납니다. 구조체 모델에 대해 찾았습니다.ConfigurationDescription의 필드 위치, 관계에 대한 유효한 외래 키를 정의해야 하거나 다음을 구현해야 합니다. Valuer/스캐너 인터페이스." 이 오류는 Gorm 문서 지침을 따르는 것처럼 보이는 데이터 모델에도 불구하고 발생합니다.

지정된 데이터 모델은 ConfigurationDescription과 LocationDescription 간의 소속 관계를 정의합니다. 그러나 ConfigurationDescription 구조체의 외래 키 태그와 참조 태그는 반대인 것으로 보입니다.

Belongs-To 관계 패턴에서 foreignKey 태그는 외부 엔터티에 조인하는 모델-로컬 키 필드의 이름을 지정해야 합니다. , 참조 태그는 외부 엔터티의 기본 키 또는 고유 키의 이름을 지정해야 합니다.

문제를 해결하려면 ConfigurationDescription 구조체의 태그를 다음과 같이 바꿔야 합니다. 다음:

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

이 태그를 수정하면 Gorm은 두 모델 간의 관계를 제대로 인식하고 외래 키 오류 없이 데이터를 성공적으로 검색해야 합니다.

위 내용은 겉보기에 올바른 모델 관계에도 불구하고 Gorm이 외래 키 오류를 발생시키는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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