
根据php小编香蕉的介绍,GORM是一款流行的Go语言ORM库,它提供了便捷的数据库操作方式。然而,GORM并不支持所有的数据类型,并且在处理某些数据类型时可能会出现错误的架构。这意味着在使用GORM时,开发者需要注意使用支持的数据类型,并确保数据架构正确,以避免潜在的问题。虽然GORM功能强大,但这些限制需要开发者在使用时谨慎处理。
gorm v1.25.1,我尝试在 worker、poster 和 job 模型上运行 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"`
}我能够通过以下代码实现您所需要的。
请注意,为了演示,我通过仅包含关联的相关字段来简化您的模型(结构)。如果我遗漏了一些值得一提的内容,请随时询问,我会更新我的答案。
我先分享一下代码,然后再详细解释。
package main
import (
"gorm.io/driver/postgres"
"gorm.io/gorm"
)
type Worker struct {
gorm.Model
Username string `gorm:"uniqueIndex;not null" json:"username"`
Posters []Poster `gorm:"many2many:workers_posters;joinForeignKey:postersId"`
}
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"`
Workers []Worker `gorm:"many2many:workers_posters;joinForeignKey:workersId"`
Jobs []Job
}
type Job struct {
gorm.Model
Title string `gorm:"uniqueIndex;not null" json:"title"`
PosterID uint `json:"posterID"`
}
func main() {
dsn := "host=localhost port=54322 user=postgres password=postgres dbname=postgres sslmode=disable"
db, err := gorm.Open(postgres.Open(dsn))
if err != nil {
panic(err)
}
db.AutoMigrate(&Worker{}, &Poster{}, &Job{})
}
由于您的问题同时涉及 many2many 和 one2many 关系,因此我将把我的答案分为两部分。
海洋影视管理系统(seacms,海洋cms)是一套专为不同需求的站长而设计的视频点播系统,灵活,方便,人性化设计简单易用是最大的特色,是快速架设视频网站首选,只需5分钟即可建立一个海量的视频讯息的行业网站。 海洋cms采用PHP+MYSQL架构,原生PHP代码带来卓越的访问速度和负载能力免去您的后顾之优。海洋cms支持一键转换原max的模板和数据,实现网站无缝迁移到新平台。众多人性化功能设计,超
116
many2many 关系要实现这种关系,您必须在保存关联实体的切片旁边添加注释 gorm:"many2many:workers_posters;joinforeignkey:workersid"。受影响的字段是:
posters 结构体中的 worker 字段workers 结构体中的 poster 字段显然,您必须根据要设置的字段更改 joinforeignkey 的值。
one2many 关系这种关系甚至更简单,因为您不必指定必须在 many2many 关联中创建的联接表(例如上面创建的 workers_posters 表)。在这里,您只需要做这两个更改:
poster 结构中添加 jobs []job 字段job 结构中添加 posterid uint 字段因此,如果您运行 automigrate 方法,您将在数据库中看到正确的表,并且所有外键都已正确设置。
请告诉我,谢谢!
以上就是GORM 不支持的数据类型:&、不正确的架构的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号