文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

如何在 gorm 中将结果表的列名从“多”更改为“多”

2024-02-10 13:32

关注

在使用 gorm 进行数据库操作时,有时候我们可能需要将结果表的列名从“多”更改为“多”。这样做可以让我们的代码更加清晰易读,提高代码的可维护性。那么,在 gorm 中如何实现这个功能呢?在本文中,php小编草莓将为大家分享一种简单有效的方法,帮助你轻松实现结果表列名的修改。

问题内容

我已经使用 typeorm 玩了很多 nestjs,现在我正在学习使用 golang 和 gorm。我正在 nestjs for go 中重建系统,在使用多对多关系时遇到问题。由于我正在使用已经在生产中并已填充的数据库,因此我需要对结构进行与其他项目相同的建模,这样就不会出现问题。

我有两个以多种方式关联的表,它们是播放列表流派,在生产数据库中它们生成playlists_genres > 具有以下字段的表:

请注意,这些字段类似于 playlistsidgenresid

在 golang 项目中,表的 m2m 结果如下:

请注意,生成的字段与我需要的不同,我需要为生产中的数据库生成标识符,即 playlistsidgenresid

我的关系代码如下所示:

type playlist struct {
    id        int32     `json:"id" gorm:"primarykey;autoincrement:true"`
    status    bool      `json:"status" gorm:"not null;default:false"`
    createdat time.time `json:"createdat" gorm:"column:created_at;autocreatetime:milli;type:timestamp without time zone;default:now();not null"`
    updatedat time.time `json:"updatedat" gorm:"column:updated_at;autoupdatetime:milli;type:timestamp without time zone;default:now();not null"`

    genres        []genre             `json:"genres" gorm:"many2many:playlists_genres"`
}

type Genre struct {
    ID          int32     `json:"id" gorm:"primaryKey;autoIncrement:true"`
    Name        string    `json:"name" gorm:"not null;type:varchar(255)"`

    Playlists    []Playlist         `json:"playlists" gorm:"many2many:playlists_genres"`
}

我查了很多资料,除了手动创建一个中间表,其中包含我需要的名称的列并将其从一个到多个关联之外,我还没有找到更改这些列名称的方法。

你能帮我解决这个问题吗?是否可以在不手动创建表的情况下执行此操作?谢谢!

解决方法

不幸的是,我认为实现您的目标的唯一方法是创建一个名为 PlaylistGenre 的结构并覆盖此处的列名称。
使用 Gorm 约定,您只能对数据库中创建的外键约束进行操作。没有机会覆盖自动创建的连接表的实际列名。
gorm 注释中,您可以使用这些属性来处理外键:foreignKeyreferencesjoinForeignKeyjoinReferences

但是,您需要使用column,这在这里是不可能的。

如果您需要这种方法的示例,请告诉我!

以上就是如何在 gorm 中将结果表的列名从“多”更改为“多”的详细内容,更多请关注编程网其它相关文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯