在PHP开发中,数据库操作是不可避免的一部分。而对于数据库操作框架GORM来说,它的灵活性和强大功能一直备受开发者们的青睐。在多对多关系的处理上,GORM提供了自定义列配置的功能,让开发者可以更加精细地控制数据表之间的关联关系。本文将由php小编西瓜为大家详细介绍如何使用GORM的自定义列配置功能来处理多对多关系,希望能帮助到大家。
问题内容
我有这 2 个模型:
type residue struct { id int name string categories []*residuecategory `gorm:"many2many:residue_residue_categories"` } type residuecategory struct { id int name string residues []*residue `gorm:"many2many:residue_residue_categories"` }
我已经有了 residue_residue_categories
表。但这些列是:
- id(整数)
- residueid(int,外键)
- residuecategoryid(int,外键)
我想做一个附加关联,例如:
db.model(&data).association("categories").append(categoriesdata)
但是 sql 生成的是:
insert into "residue_residue_categories" ("residue_id","residue_category_id") values (49,4) on conflict do nothing
如您所见,插入 sql 中的列名称不正确。
我已经尝试配置其他字段,例如:
categories []*residuecategory `gorm:"many2many:residue_residue_categories;foreignkey:residueid;association_foreignkey:residuecategoryid"`
Residues []*Residue `gorm:"many2many:residue_residue_categories;association_foreignkey:residueId;foreignkey:residueCategoryId"`
但奇怪的是,gorm 在一个简单的 getbyid
中抛出: invalid 外键:residualid
(在追加关系之前)。我如何配置与这些自定义列名称的关系?
解决方法
我整理了一个小例子来尝试解决您的问题。首先,让我分享代码,然后我将引导您完成代码的所有相关部分。
package main import ( "fmt" "gorm.io/driver/postgres" "gorm.io/gorm" ) type Residue struct { ID int Name string ResidueResidueCategories []*ResidueResidueCategory } type ResidueResidueCategory struct { ID int `gorm:"primaryKey"` ResidueCategoryId int `gorm:"column:residueCategoryId"` ResidueId int `gorm:"column:residueId"` } type ResidueCategory struct { ID int Name string ResidueResidueCategories []*ResidueResidueCategory } 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(&Residue{}, &ResidueCategory{}, &ResidueResidueCategory{}) // insert into parent tables db.Create(&Residue{ID: 1, Name: "residue 1"}) db.Create(&ResidueCategory{ID: 1, Name: "category 1"}) // insert into join table db.Debug().Model(&Residue{ID: 1}).Association("ResidueResidueCategories").Append(&ResidueResidueCategory{ResidueCategoryId: 1, ResidueId: 1}) // fetch data var joinTableRecords []ResidueResidueCategory if err := db.Model(&ResidueResidueCategory{}).Find(&joinTableRecords).Error; err != nil { panic(err) } for _, v := range joinTableRecords { fmt.Println(v) } }
现在,让我们仔细看看每个部分。
结构体的定义已经发生了很大的变化。我必须插入连接表的定义并覆盖其列名称。
请注意,我添加定义只是为了完整性,如果您的连接表已存在于数据库中,您可以忽略它。
另一个变化是我如何将数据插入数据库。首先,您必须在父表(residues
和 residue_categories
)中插入数据,然后您可以在 residues
和 residue_categories
)中插入数据,然后您可以在 residue_residue_categories
连接表中添加关联。
我添加了 debug()
方法来向您显示发送到数据库的 sql 语句,即使您在不附加调试器的情况下运行代码也是如此。
为了勉强关注逻辑,我在程序中硬编码了一些值,但应该很容易调整到您自己的逻辑。
如果这解决了您的问题,请告诉我,谢谢!
以上是GORM 使用自定义列配置多对多的详细内容。更多信息请关注PHP中文网其他相关文章!

C 更适合需要直接控制硬件资源和高性能优化的场景,而Golang更适合需要快速开发和高并发处理的场景。1.C 的优势在于其接近硬件的特性和高度的优化能力,适合游戏开发等高性能需求。2.Golang的优势在于其简洁的语法和天然的并发支持,适合高并发服务开发。

Golang在实际应用中表现出色,以简洁、高效和并发性着称。 1)通过Goroutines和Channels实现并发编程,2)利用接口和多态编写灵活代码,3)使用net/http包简化网络编程,4)构建高效并发爬虫,5)通过工具和最佳实践进行调试和优化。

Go语言的核心特性包括垃圾回收、静态链接和并发支持。1.Go语言的并发模型通过goroutine和channel实现高效并发编程。2.接口和多态性通过实现接口方法,使得不同类型可以统一处理。3.基本用法展示了函数定义和调用的高效性。4.高级用法中,切片提供了动态调整大小的强大功能。5.常见错误如竞态条件可以通过gotest-race检测并解决。6.性能优化通过sync.Pool重用对象,减少垃圾回收压力。

Go语言在构建高效且可扩展的系统中表现出色,其优势包括:1.高性能:编译成机器码,运行速度快;2.并发编程:通过goroutines和channels简化多任务处理;3.简洁性:语法简洁,降低学习和维护成本;4.跨平台:支持跨平台编译,方便部署。

关于SQL查询结果排序的疑惑学习SQL的过程中,常常会遇到一些令人困惑的问题。最近,笔者在阅读《MICK-SQL基础�...

golang ...

Go语言中如何对比并处理三个结构体在Go语言编程中,有时需要对比两个结构体的差异,并将这些差异应用到第�...


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

记事本++7.3.1
好用且免费的代码编辑器

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

SublimeText3汉化版
中文版,非常好用