>백엔드 개발 >Golang >GORM이 지원하지 않는 데이터 유형: &, 잘못된 스키마

GORM이 지원하지 않는 데이터 유형: &, 잘못된 스키마

WBOY
WBOY앞으로
2024-02-12 21:18:09552검색

GORM 不支持的数据类型:&、不正确的架构

PHP 편집기 Banana의 소개에 따르면 GORM은 편리한 데이터베이스 작업 방법을 제공하는 인기 있는 Go 언어 ORM 라이브러리입니다. 그러나 GORM은 모든 데이터 유형을 지원하지 않으며 특정 데이터 유형을 처리할 때 잘못된 스키마가 발생할 수 있습니다. 이는 GORM을 사용할 때 개발자가 지원되는 데이터 유형 사용에 주의를 기울여야 하며 잠재적인 문제를 피하기 위해 데이터 스키마가 올바른지 확인해야 함을 의미합니다. GORM은 강력하지만 이러한 제한 사항으로 인해 개발자는 GORM을 사용할 때 주의해서 처리해야 합니다.

질문 내용

gorm v1.25.1, 저는 workerposterjob 模型上运行 db.automigrate(),但遇到 [错误] 不支持的数据类型:&[]。 worker 和 job 结构应该具有 many-to-many 关系 ,而 poster 和 job 应该具有 one-to-many 关系。工人和经验、工人和偏好都应该是 one-to-many관계를 시도합니다. 도와주세요.

package model

type experience struct {
    gorm.Model
    Company  int    `json:"company"`
    JobTitle string `json:"jobTitle"`
    WorkerID uint
}

type preference struct {
    gorm.Model
    JobTitle string `json:"JobTitle"`
    MinPay   int    `json:"minPay"`
    MaxPay   int    `json:"maxPay"`
    WorkerID uint
}

type Worker struct {
    gorm.Model
    Username     string       `gorm:"uniqueIndex;not null" json:"username"`
        ...more fields
    Experience   []experience `json:"experience"`
    Preference   []preference `json:"preference"`
    AppliedJobs  []Job        `gorm:"many2many:worker_jobs;" json:"appliedJobs"`
}

type Poster struct {
    gorm.Model
    Name       string `gorm:"uniqueIndex;not null" json:"name"`
    Email      string `gorm:"uniqueIndex;not null" json:"email"`
    Phone      string `json:"phone"`
    JobsPosted []Job  `json:"jobsPosted"`
}

type Job struct {
    gorm.Model
    Title       string   `gorm:"uniqueIndex;not null" json:"title"`
        ...more fields
    PosterID uint `json:"posterID"`
}

해결 방법

다음 코드를 사용하여 필요한 것을 얻을 수 있었습니다.

시연을 위해 협회의 관련 분야만 포함하여 모델(구조)을 단순화했습니다. 언급할 만한 가치가 있는 내용을 놓친 경우 언제든지 문의해 주시면 답변을 업데이트하겠습니다.

코드를 먼저 공유한 후 자세히 설명드리겠습니다.

으아아아

귀하의 질문이 두 many2manyone2many 관계 모두에 적용되므로 답변을 두 부분으로 나누겠습니다.

many2many 관계

이 관계를 구현하려면 연관된 엔터티를 보유하는 슬라이스 옆에 주석 gorm:"many2many:workers_posters;joinforeignkey:workersid"을 추가해야 합니다. 영향을 받는 필드는 다음과 같습니다.

  • posters 结构体中的 worker 필드
  • workers 结构体中的 poster 필드

분명히 설정하려는 필드에 따라 joinforeignkey 값을 변경해야 합니다.

one2many 관계

이 관계는 many2many 关联中创建的联接表(例如上面创建的 workers_posters 연관에서 생성되어야 하는 조인 테이블(예: 위에서 생성된 workers_posters 테이블)을 지정할 필요가 없기 때문에 더욱 간단합니다. 여기서는 다음 두 가지만 변경하면 됩니다:

  1. poster 结构中添加 jobs []job분야
  2. 에서
  3. job 结构中添加 posterid uint분야
  4. 에서

그래서 automigrate 메소드를 실행하면 데이터베이스에 올바른 테이블이 표시되고 모든 외래 키가 올바르게 설정된 것을 볼 수 있습니다.

말해주세요, 감사합니다!

위 내용은 GORM이 지원하지 않는 데이터 유형: &, 잘못된 스키마의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 stackoverflow.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제